ArrayList简介
ArrayList是一个基于双向链表实现的集合,由于无法对元素进行随机访问,LinkedList
仅仅在头尾插入或者删除元素的时候时间复杂度近似 O(1),其他情况增删元素需要移动到指定位置,平均时间复杂度都是 O(n)。ArrayList的性能通常会比LinkedList更好,所以不要下意识地认为 LinkedList
作为链表就最适合元素增删的场景。
LinkedList类图
由类图我们可以知道LinkedList同样继承了 AbstractList,因此
LinkedList
会有大部分方法和 ArrayList
相似。同时,其支持深浅拷贝,序列化操作,并且具有双端队列的特性。
为什么LinkedList不支持随机访问?
LinkedList底层数据结构是一个双向链表,内存地址并不是连续的,不支持随机访问。
获取元素
调用get(int index)函数
获取链表指定位置的元素,其内部调用了node(int index)函数,该方法通过比较索引值与链表的一半大小来确定从链表头还是尾开始遍历。充分利用了双向链表的特性来提高效率。
遍历列表
使用for-each
循环来遍历 LinkedList
中的元素时,for-each
循环最终会转换成迭代器形式 。 迭代器在遍历列表时会比较exceptedModCount和链表的modCount,以此判断链表是否被其他的线程修改过。在遍历过程中,如果要对链表执行删除或添加元素操作,应该使用迭代器进行操作,否则迭代器会抛出异常。