arraylist、vector和linkedlist的区别

1.从存储数据结构分析

ArrayList:数组

Vector:数组

LinkedList:双向链表

数组:可以根据下标快速查找,所以大部分情况下,查询快。但是如果要进行增删操作的时候,会需要移动修改元素后面的所有元素,所以增删的开销比较大,数组的对增删操作的执行效率低。而采用数组作为数据存储结构的ArrayList、Vector也存在这些特性,查询速度快(可以根据下标直接取,比迭代查找更快),增删慢。

链表:增加和删除元素方便,增加或删除一个元素,仅需处理结点间的引用即可。就像人手拉手连成一排,要增加或删除某个人只要附近的两个人换一个人牵手,对已经牵好手的人没影响。无论在哪里换人耗费的资源和时间都是一样的。但是查询不方便,需要一个个对比,无法根据下标直接查找。而采用链表结构存储的LinkedList也有这些特性,增删方便,查询慢(指的是随机查询,不是顺序查询)。
3.从并发安全上分析
Vector:线程安全(synchronized同步)
ArrayList:非线程安全
LinkedList:非线程安全
4、扩容:
ArrayList 与Vector 都有一个初始的容量大小,当存储进他们里面的元素个数超过了容量时,就需要增加ArrayList与Vector的存储空间, 每次要增加存储空间时,不是只增加一个存储单元,而是增加多个存储单元,每次增加的存储单元的个数在内存空间利用与程序效率之间要取的一定的平衡。Vector默认增加为原来的两倍,而ArrayList默认为 1.5倍,ArrayList和Vector都可以设置初始的空间大小,Vector还可以设置增长的空间大小,而Arraylist 没有设置增长空间的方法。 即Vector增长原来的1倍,Arraylist增长原来的0.5倍

ArrayListVectorLinkedListJava中常用的集合类,它们都实现了List接口,但在实现细节上有一些区别。 1. 线程安全性: - ArrayListLinkedList是非线程安全的,不适合在多线程环境中使用。 - Vector是线程安全的,它通过使用synchronized关键字来保证线程安全性。但是这也导致了在并发情况下性能较差。 2. 底层实现: - ArrayListVector底层都使用数组实现,支持随机访问元素,根据索引获取元素的时间复杂度为O(1)。 - LinkedList底层使用双向链表实现,不支持随机访问元素,根据索引获取元素的时间复杂度为O(n),但在插入和删除元素时具有较好的性能,时间复杂度为O(1)。 3. 动态扩容: - ArrayListVector在需要扩容时会自动增加容量ArrayList默认扩容为原来容量的1.5倍,Vector默认扩容为原来容量的2倍。 - LinkedList没有固定的容量限制,可以动态增加节点。 4. 迭代器: - ArrayListVector通过Iterator迭代器进行遍历。 - LinkedList除了支持Iterator迭代器外,还可以通过getFirst()、getLast()、next()等方法进行遍历。 5. 性能比较: - ArrayList在读取元素和修改元素时性能较好,适合随机访问。 - LinkedList在插入和删除元素时性能较好,适合频繁的插入和删除操作。 综上所述,选择使用ArrayList还是Vector还是LinkedList,取决于具体的使用场景和需求。如果需要线程安全性,可以选择Vector;如果需要频繁的插入和删除操作,可以选择LinkedList;如果需要随机访问元素,可以选择ArrayList
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值