ArrayList和LinkedList的底层实现原理

1.ArrayList
ArrayList 通过数组实现,一旦我们实例化 ArrayList 无参数构造函数默认为数组初始化长度为 10②,add 方法底层实现如果增加的元素个数超过了 10 个,那么 ArrayList 底层会新生成一个数组,长度为原数组的 1.5 倍+1,然后将原数组的内容复制到新数组当中,并且后续增加的内容都会放到新数组当中。当新数组无法容纳增加的元素时,重复该过程。是一旦数组超出长度,就开始扩容数组。扩容数组调用的方法 Arrays.copyOf(objArr, objArr.length + 1);
在这里插入图片描述
2.LinkedList
LinkedList 底层的数据结构是基于双向循环链表的,且头结点中不存放数据,
既然是双向链表,那么必定存在一种数据结构——我们可以称之为节点,节点实例保存业务数据,前一个节点的位置信息和后一个节点位置信息
在这里插入图片描述
区别:
1.ArrayList是实现了基于动态数组结构,LinkedList是基于链表数据结构.
2.对于随机访问get和set,ArrayList优于Linkedlist,因为ArrayList可以随机定位,而linkedList要移动指针一步一步的移动到节点处.
3.对于新增和删除操作,linkedlist比较占优势,只需要对指针进行修改即可,而ArrayList要移动数据来填补被删除的对象的空间

使用场景
(1)如果应用程序对各个索引位置的元素进行大量的存取操作,ArrayList对象要远优于LinkedList对象;
(2)如果应用程序主要是对列表元素进行循环,并且循环时候进行插入或者删除操作,LinkedList对象要远优于ArrayList对象

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值