首页 > 其他 > 详细

ArrayList和LinkedList内部是怎么实现的?他们之间的区别和优缺点?

时间:2021-06-08 17:06:09      阅读:18      评论:0      收藏:0      [点我收藏+]

ArrayList

内部使用了数组形式进行了存储,利用数组的下标进行元素的访问,因此对元素的随机访问速度非常快。因为是数组,所以ArrayList在初始化的时候,
有初始大小10,插入新元素的时候,会判断是否需要扩容,
扩容的步长是0.5倍原容量,扩容方式是利用数组复制,因此有一定的开销。

LinkedList

内部使用双向链表的结构实现存储,LinkedList有一个内部类作为存放元素单元,里面有三个属性,用来存放元素本身以及前后两个单元的引用,另外LindedList的
内部还有一个header属性,用来标识起始位置,LinkedList的第一个单元和最后一个单元都会指向header,因此形成了一个双向的链表结构

ArrayList和LinkedList的区别

ArrayList查找较快,插入删除较慢,LinkedList查找较慢,插入删除较快

ArrayList和LinkedList内部是怎么实现的?他们之间的区别和优缺点?

原文:https://www.cnblogs.com/songwp/p/14862756.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!