欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

ArrayList和LinkedList区别(蚂蚁金服面试题)

程序员文章站 2023-01-29 23:52:59
1. 是否保证线程安全: ArrayList 和 LinkedList 都是不同步的,也就是不保证线程安全; 2. 底层数据结构: Arraylist 底层使用的是Object数组;LinkedList 底层使用的是双向链表数据结构(JDK1.6之前为循环链表,JDK1.7取消了循环。注意双向链表和 ......
  • 1. 是否保证线程安全: arraylist 和 linkedlist 都是不同步的,也就是不保证线程安全;

  • 2. 底层数据结构: arraylist 底层使用的是object数组;linkedlist 底层使用的是双向链表数据结构(jdk1.6之前为循环链表,jdk1.7取消了循环。注意双向链表和双向循环链表的区别,下面有介绍到!)

  • 3. 插入和删除是否受元素位置的影响: ① 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)。

  • 4. 是否支持快速随机访问: linkedlist 不支持高效的随机元素访问,而 arraylist 支持。快速随机访问就是通过元素的序号快速获取元素对象(对应于get(int index)方法)。

  • 5. 内存空间占用: arraylist的空 间浪费主要体现在在list列表的结尾会预留一定的容量空间,而linkedlist的空间花费则体现在它的每一个元素都需要消耗比arraylist更多的空间(因为要存放直接后继和直接前驱以及数据)

           本文转载自公众号:hollis 作者:泽林