JavaSE阶段回顾(11)集合之list集合

本文深入解析Java中的List集合,包括ArrayList、LinkedList和Vector的特点及应用场景。对比了它们在实现方式、性能表现和线程安全性上的差异,帮助开发者选择最适合项目需求的集合类型。
摘要由CSDN通过智能技术生成

常见集合

在这里插入图片描述

List集合

ArrayList

• ArrayList是一个用数组实现的列表,也是我们最常用的集合。它允许任何符合规则的元素插入甚至包括null
• 每一个ArrayList都有一个初始容量(10),该容量代表了数组的大小。随着容器中的元素不断增加,容器的大小也会随着增加。在每次向容器中增加元素的同时都会进行容量检查,当快溢出时,就会进行扩容操作(构建一个新的更大的数组并将之前的内容拷贝到新书组中)。所以如果我们明确所插入元素的多少,最好指定一个初始容量值,避免过多的进行扩容操作而浪费时间、效率
• ArrayList的默认扩容扩展后数组大小为:(原数组长度*3)/2+1
• ArrayList是一个非线程安全的列表

LinkedList

• 同样实现List接口的LinkedList与ArrayList不同,LinkedList是一个双向链表。所以它除了有ArrayList的基本操作方法外还额外提供了get,remove,insert方法在LinkedList的首部或尾部
• 由于实现的方式不同,LinkedList不能随机访问,它所有的操作都是要按照双重链表的需要执行。在列表中索引的操作将从开头或结尾遍历列表(从靠近指定索引的一端)。这样做的好处就是可以通过较低的代价在List中进行插入和删除操作
• 与ArrayList一样,LinkedList也是非同步的。如果多个线程同时访问一个List,则必须自己实现访问同步

Vector

• Vector与ArrayList相似,但是Vector是同步的。所以说Vector是使用数组实现的线程安全的列表。它的操作与ArrayList几乎一样
• Vector在进行默认规则扩容时,新数组的长度=原始数组长度*2

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值