| |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
-> Java知识库 -> Java集合看这一系列就够了---2 -> 正文阅读 |
|
[Java知识库]Java集合看这一系列就够了---2 |
目录 一、List动态数组。元素是有序的,且可以重复。 List接口有三个实现类:ArrayList、LinkedList、Vector。 1.经典面试题: ArrayList、LinkedList、Vector三者的异同。 答: ①三个类都实现了List接口,存储数据的特点相同;存储有序的可重复的数据。 ②List的主要实现类为ArrayList,Vector为其古老的实现类。 ③ArrayList执行效率高,线程安全,底层使用object[]数组;Vector线程安全,效率低,底层使用Object[] ④LinkedList底层使用双向链表存储,对于频繁的插入、删除操作,使用此类效率比arrayList高。 二、ArrayList源码分析底层使用Object[]实现。 1.JDK 7
2.启示 建议开发中使用带参的构造器,参数指定为其容量,默认的无参构造器初始容量为10。 3.JDK 8 与JDK 7的不同:
?4.总结 JDK?8的改变:在创建list时并不创建数组,而是赋值为{},在添加时再创建长度为10的数组,优化了内存。 JDK 7的创建类似于单例的饿汉式;而JDK 8中的ArrayList的对象的创建类似于单例模式的懒汉式,延迟了数组的创建,节省了内存。 三、LinkedList源码分析底层使用链表实现,有频繁的插入和删除时使用LinkedList。
四、Vector源码分析?线程安全的,效率低,底层使用Object[]; add时扩容为原来的2倍。创建时创建了长度为10的数组,Vector基本上不使用了 |
|
|
上一篇文章 下一篇文章 查看所有文章 |
|
开发:
C++知识库
Java知识库
JavaScript
Python
PHP知识库
人工智能
区块链
大数据
移动开发
嵌入式
开发工具
数据结构与算法
开发测试
游戏开发
网络协议
系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程 数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁 |
360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 | -2024/11/24 5:04:02- |
|
网站联系: qq:121756557 email:121756557@qq.com IT数码 |