30.1.List 接口基本介绍
List 接口是 Collection 接口的子接口
- List 集合类中元素有序(即 添加顺序 和 取出顺序 一致,不是指元素值大小排列顺序)、且可重复
- List 集合中的每个元素都有其对应的顺序索引,即支持索引
- List 容器中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据序号存取容器中的元素
30.2.List 接口常用方法
List 集合里添加了一些根据索引来操作集合的方法
void add(int index, Object ele)
:在 index 位置插入 ele 元素boolean addAll(int index,Collection eles)
:从 index 位置开始将 eles 中的所有元素添加进来Object get(int index)
:获取指定 index 位置的元素int indexOf(Object obj)
:返回 obj 在当前集合中首次出现的位置int lastIndexOf(Object obj)
:返回 obj 在当前集合中末次出现的位置Object remove(int index / Object)
:移除指定 index 位置的元素,并返回此元素,也可以移除指定元素Object set(int index,Object ele)
:设置指定 index 位置的元素为 ele,相当于是替换List subList(int fromIndex,int toIndex)
:返回从 fromIndex 到 toIndex 位置的子集合
30.3.ArrayList 类
- 可以加入 null ,并且多个
- 是由数组来实现数据存储的
- 基本等同于 Vector,执行效率高,但 线程不安全,适合单线程,不适合多线程
ArrayList 底层操作机制(看源码)
- 维护了一个 Object 类型的数组 elementData
transient Object[] elementData;
- 当创建ArrayList对象时,如果使用的是无参构造器,则初始化 elementDate 容量为 0 ,第一次添加,则扩容 elementData 为 10,如需要再次扩容,则扩容 elementData 为 1.5 倍
- 如果使用的是指定大小的构造器,则初始 elementData 容量为指定大小,如果需要扩容,则直接扩容 elementData 为 1.5 倍
30.4.Vector 类
- Vector 底层也是一个对象数组
protected Object[] elementData;
- 是线程同步的,即 线程安全
- 在开发中,需要线程同步安全,考虑使用 Vector
Vector 和 ArrayList 的比较
| 底层结构 | 版本 | 线程安全(同步)效率 | 扩容倍数 |
---|
ArrayList | 可变数组 | JDK 1.2 | 不安全,效率高 | 如果有参构造1.5倍;无参第一次10,第二次开始按1.5倍扩 |
Vector | 可变数组 | JDK 1.0 | 安全,效率不高 | 如果是无参,默认10,满后就按2倍扩容;如果指定大小,则每次直接按2倍扩 |
30.5.LinkedList 类
- LinkedList 底层实现了双向链表和双端队列特点
- 可以添加任意元素(元素可重复),包括 Null
- 线程不安全,没有实现同步
LinkedList 的底层操作机制
- LinkedList 底层维护了一个双向链表
- LinkedList 中维护两个属性 first 和 last 分别指向 首节点和尾节点
- 每个节点(Node对象),里面又维护了 prev、next、item 三个属性,其中通过prev指向前一个,通过next指向后一个节点,最终实现双向链表
- 添加和删除不是通过数组完成,相对来说效率更高
class Node {public Object item;public Node next;public Node pre;public Node(Object name) {this.item = name;}public String toString() {return "Node name=" + item;}
}
ArrayList 和 LinkedList 的比较
| 底层结构 | 增删的效率 | 改查的效率 |
---|
ArrayList | 可变数组 | 较低(数组扩容) | 较高(根据索引) |
LinkedList | 双向链表 | 较高(通过链表追加) | 较低 |
30.6.如何选择 ArrayList 、LinkedList 、Vector:
- 如果改查的操作多,选择 ArrayList
- 如果增删的操作多,选择 LinkedList
- ArrayList 和 LinkedList 是针对于单线程情况,若在多线程情况下,则选择 Vector