码迷,mamicode.com
首页 > 其他好文 > 详细

ArrayList和LinkedList区别

时间:2015-08-17 17:32:08      阅读:131      评论:0      收藏:0      [点我收藏+]

标签:

ArrayList和LinkedList区别:

一句话概括:ArrayList 通过的是数组形式来存贮管理对象的,LinkedList是通过链表的方式。


共同点:

LinkedeList和ArrayList都实现了List接口

ArrayList和LinkedList是两个集合类,用于存储一系列的对象引用(references)。

但是它们的工作原理却不一样。

它们之间最主要的区别在于ArrayList是可改变大小的数组,而LinkedList是双向链接串列(doubly LinkedList)。

ArrayList更受欢迎,很多场景下ArrayList比LinkedList更为适用。

区别:

ArrayList进行随机访问所消耗的时间是固定的,因此随机访问时效率比较高。

LinkedList是不支持快速的随机访问的,但是在插入删除时效率比较高。


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

LinkedList中的get方法是按照顺序从列表的一端开始检查,直到另外一端。所以随机访问时ArrayList效率明显比LinkedList效率要高。


但是在大量插入删除操作上LinkedList效率又明显比ArrayList要高。


这里要提出来说的是在开端和末端插入数据时的情况。

1.ArrayList是实现了基于动态数组的数据结构,LinkedList基于链表的数据结构。
2.对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针。
3.对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据。
    这一点要看实际情况的。

若只对单条数据插入或删除,ArrayList的速度反而优于LinkedList。

但若是批量随机的插入删除数据,LinkedList的速度大大优于ArrayList. 因为ArrayList每插入一条数据,要移动插入点及之后的所有数据。  

这一点我做了实验。在分别有200000条“记录”的ArrayList和LinkedList的首位插入20000条数据,LinkedList耗时约是ArrayList的20分之1。  


当一个元素被加到ArrayList的最开端时,所有已经存在的元素都会后移,意味着数据移动和复制上的开销,因此效率较低。

相反的,将一个元素加到LinkedList的最开端只是简单的未这个元素分配一个记录,然后调整两个连接。所以效率比较高。


在 LinkedList的开端增加一个元素的开销是固定的,而在ArrayList的开端增加一个元素的开销是与ArrayList的大小成比例的。


1.对ArrayList和LinkedList而言,在列表末尾增加一个元素所花的开销都是固定的。对 ArrayList而言,主要是在内部数组中增加一项,指向所添加的元素,偶尔可能会导致对数组重新进行分配;而对LinkedList而言,这个开销是 统一的,分配一个内部Entry对象。

  2.在ArrayList的中间插入或删除一个元素意味着这个列表中剩余的元素都会被移动;而在LinkedList的中间插入或删除一个元素的开销是固定的。

  3.LinkedList不支持高效的随机元素访问。

  4.ArrayList的空间浪费主要体现在在list列表的结尾预留一定的容量空间,而LinkedList的空间花费则体现在它的每一个元素都需要消耗相当的空间

  可以这样说:当操作是在一列 数据的后面添加数据而不是在前面或中间,并且需要随机地访问其中的元素时,使用ArrayList会提供比较好的性能;当你的操作是在一列数据的前面或中 间添加或删除数据,并且按照顺序访问其中的元素时,就应该使用LinkedList了。


LinkedList和ArrayList的差别主要来自于Array和LinkedList数据结构的不同。如果你很熟悉Array和LinkedList,你很容易得出结论:


1) 因为Array是基于索引(index)的数据结构,它使用索引在数组中搜索和读取数据是很快的。Array获取数据的时间复杂度是O(1),但是要删除数据却是开销很大的,因为这需要重排数组中的所有数据。


2) 相对于ArrayList,LinkedList插入是更快的。

因为LinkedList不像ArrayList一样,不需要改变数组的大小,也不需要在数组装满的时候要将所有的数据重新装入一个新的数组,这是ArrayList最坏的一种情况,时间 复杂度是O(n),而LinkedList中插入或删除的时间复杂度仅为O(1)。

ArrayList在插入数据时还需要更新索引(除了插入数组的尾部)。


3) 类似于插入数据,删除数据时,LinkedList也优于ArrayList。


4) LinkedList需要更多的内存,因为ArrayList的每个索引的位置是实际的数据,而LinkedList中的每个节点中存储的是实际的数据和前后节点的位置。


什么场景下更适宜使用LinkedList,而不用ArrayList


我前面已经提到,很多场景下ArrayList更受欢迎,但是还有些情况下LinkedList更为合适。譬如:


1) 你的应用不会随机访问数据。因为如果你需要LinkedList中的第n个元素的时候,你需要从第一个元素顺序数到第n个数据,然后读取数据。


2) 你的应用更多的插入和删除元素,更少的读取数据。因为插入和删除元素不涉及重排数据,所以它要比ArrayList要快。


以上就是关于ArrayList和LinkedList的差别。你需要一个不同步的基于索引的数据访问时,请尽量使用ArrayList。ArrayList很快,也很容易使用。但是要记得要给定一个合适的初始大小,尽可能的减少更改数组的大小。

总结:

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

2. 对于随机访问get和set,ArrayList觉得优于LinkedList,因为LinkedList要移动指针。

3. 对于新增和删除操作add和remove,LinedList比较占优势,因为ArrayList要移动数据


以上ArrayList和LinkedList的区别重复不止一遍了,如果你看完再理解不了那也说不过去了吧。呵呵





    
        

版权声明:本文为博主原创文章,未经博主允许不得转载。

ArrayList和LinkedList区别

标签:

原文地址:http://blog.csdn.net/singit/article/details/47725767

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!