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

ArrayList 的实现原理

时间:2015-09-25 20:16:45      阅读:151      评论:0      收藏:0      [点我收藏+]

标签:

ArrayList  是List接口的可变数组的实现。实现了所有可选列表的操作,并包括null值在内的所有元素。此类还提供了一些方法来操作内部用来存储列表的数组大小。

ArrayList 的是实现:

    对于ArrayList而言,他实现List接口、底层使用数组保存所有元素,其操作基本上是对数组的操作。

 

 

LinkedList  实现了List接口,但是它执行和插入操作时比ArrayList更加高效,因为它是基于链表,基于链表也决定了它在随机访问方面要比ArrayList逊色一些。

  除此之外,LinkedLis还提供一些可以使其作为栈、队列、双端队列的方法,这些方法中彼此之间只是名称的区别,以使得这些名字在等特定的上下文中显得更加合适。、

 

 

 

ArrayList(访问快速,修改慢)的底层使用的是数组存元素,数组的大小说是自增的,(插入元素,由于不知道数组容量,数组要复制到一个新的数组中,)。

LinkedList (改快查慢)的底层是链表,通过节点直接将元素连接起来,每个节点包含前后节点的引用和节点存储的值,

当修改时,插入一个新的元素,只需要修改前后节点的引用关系即可,

但访问是,要遍历节点来定位,所以访问速度慢。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

ArrayList 的实现原理

标签:

原文地址:http://www.cnblogs.com/chengbao/p/4839196.html

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