ArrayList、LinkedList、Vector 的区别?

本文探讨了ArrayList, Vector和LinkedList这三种Java集合类的底层实现及其性能特性。ArrayList和Vector基于数组,适合查询操作,但插入速度较慢;LinkedList采用双线链表,插入速度快但查询效率低。由于Vector使用了线程安全,其性能低于非同步的ArrayList。此外,还介绍了它们各自常用的方法,如ArrayList的indexOf()和LinkedList的添加、删除首尾元素操作。了解这些可以帮助开发者根据实际需求选择合适的数据结构。

ArrayList , Vector 底层是由数组实现 ,LinkedList  底层是由双线链表实现,从底层的实现可以得出它们的性能问题,

ArrayList,Vector 插入速度相对较慢,查询速度相对较快

LinkedList 插入速度较快,而查询速度较慢。

再者由于 Vevtor 使用了线程安全锁,所以ArrayList 的运行效率高于 Vector。

ArrayList和LinkedList

相同点:都继承了list接口,都是对数据的增删改查,获得子集合,访问属性

不同点:数据结构不同,

ArrayList:实现了可变数组,可以快速查询数据,常用的方法有indexOf();

Linkedlist:链表数据结构,可以快速修改其中元素,常用的方法有

.addFifst("##")   //把一个元素添加到第一个位置

.addLast("##")   //把一个元素添加到最后一个位置

.removeFirst     //删除第一个

.removeList     //删除最后一个

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值