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

ArrayList和LinkedList

时间:2017-09-08 18:15:31      阅读:158      评论:0      收藏:0      [点我收藏+]

标签:src   删除   nbsp   使用   属性   between   分配   linked   class   

ArrayList:

 

1、初始容量

       List arrayList = new ArrayList();默认初始容量为10 ,当ArrayList中的元素超过10个以后,会重新分配内存空间,使数组的大小增长到16。那么容量变化的规则是((旧容量 * 3) / 2) + 1
  2、常用方法

     1>list.add("a");

      技术分享

    2>list.remove(2);

技术分享

 

    3>list.clear();清空

LinkedList:

 1、属性

  LinkedList不可以在初始化时候指定大小,每次向其中加入元素时候,容量自动加1。

相同点:

   LinkedeList和ArrayList都实现了List接口

不同点:

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中的每个节点中存储的是实际的数据和前后节点的位置。

 

实际上只有乱序查询时ArrayList优于LinkedList,顺序查询时两者所需时间相同

ArrayList和LinkedList

标签:src   删除   nbsp   使用   属性   between   分配   linked   class   

原文地址:http://www.cnblogs.com/lc-java/p/7495269.html

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