美文网首页JavaEE Note程序员
ArrayList和LinkedList的区别

ArrayList和LinkedList的区别

作者: chcvn | 来源:发表于2017-11-23 16:59 被阅读37次

大致的区别:

  • ArrayList是实现了基于动态数组的数据结构, LinkedList基于链表的数据结构

  • 对于随机访问get和set,ArrayList优于LinkedList,因为ArrayList可以随机定位,而LinkedList要移动指针一步一步的移动到节点处
    (举例:因为ArrayList的底层是动态数组,它属于一个对象,而LinkedList是链表,它是跟很多对象有关联的,所以, 你查询的话,数组就很快了,相对Linked而言,它联系着很多的对象,查询的时候,你要把他们都查出来,这个时候从性能和时间上,linkedList就不如ArrayList!)

  • 对于新增和删除操作add和remove,LinedList比较占优势,只需要对指针进行修改即可,而ArrayList要移动数据来填补被删除的对象的空间。
    (ArrayList在添加和删除的时候,底层是创建一个新的数组,而LinkedList却只要修改一下指针就ok了)

什么时候用哪个?

首先ArrayList和linkedList 是两个集合类,用于存储一系列的对象引用

1.ArrayList的内部实现是基于基础的对象数组的,因此,它使用get方法访问列表中的任意一个元素时(random access),它的速度要比LinkedList快

2.LinkedList中的get方法是按照顺序从列表的一端开始检查,直到另外一端。对LinkedList而言,访问列表中的某个指定元素没有更快的方法了。

3.当操作是在一列数据的后面添加数据而不是在前面或中间,并且需要随机地访问其中的元素时,使用ArrayList会提供比较好的性能;

4.当你的操作是在一列数据的前面或中间添加或删除数据,并且按照顺序访问其中的元素时,就应该使用LinkedList了。

所以, 简单的来说

<font color="red">业务如果查询多,就用ArrayList
业务添加或者删除的多 就用 linkedList</font>

思维导图如下:

[图片上传失败...(image-93c3fb-1511427580638)]

相关文章

网友评论

    本文标题:ArrayList和LinkedList的区别

    本文链接:https://www.haomeiwen.com/subject/yuozvxtx.html