线程安全:ArrayList和LinkedList都不是线程安全的。 底层数据结构:ArrayList底层采用的是Object数组,LinkedList底层是双向链表数据结构 插入和删除是否受位置影响:① ArrayList 采用数组存储,所以插入和删除元素的时间复杂度受元素位置的影响。 比如:执行add(E e)方法的时候, ArrayList 会默认在将指定的元素追加到此列表的末尾,这种情况时间复杂度就是O(1)。但是如果要在指定位置 i 插入和删除元素的话(add(int index, E element))时间复杂度就为 O(n-i)。因为在进行上述操作的时候集合中第 i 和第 i 个元素之后的(n-i)个元素都要执行向后位/向前移一位的操作。 ② LinkedList 采用链表存储,所以插入,删除元素时间复杂度不受元素位置的影响,都是近似 O(1)而数组为近似 O(n)。 是否支持随机快速访问:LinkedList不支持随机快速访问,ArrayList支持。(get方法) 内存空间占用:LinkedList每个元素所占空间比ArrayList多,因为是双向链表所以要有额外的空间来存放直接前驱和直接后继。

相关推荐

牛客网
牛客企业服务