是否保证线程安全: ArrayList
和 LinkedList
都是不同步的,也就是不保证线程安全
底层数据结构: Arraylist
底层使用的是 Object
数组;LinkedList
底层使用的是 双向链表 数据结构
插入和删除是否受元素位置的影响: ① ArrayList
采用数组存储,所以插入和删除元素的时间复杂度受元素位置的影响;LinkedList
采用链表存储,所以对于add(�E e)
方法的插入,删除元素时间复杂度不受元素位置的影响,近似 O(1)
是否支持快速随机访问: LinkedList
不支持高效的随机元素访问,而 ArrayList
支持。快速随机访问就是通过元素的序号快速获取元素对象(对应于get(int index)
方法)。
内存空间占用: ArrayList的空 间浪费主要体现在在list列表的结尾会预留一定的容量空间,而LinkedList的空间花费则体现在它的每一个元素都需要消耗比ArrayList更多的空间
链表