ArrayList和LinkedList的区别和使用场景

先看看接口关系
image

1.ArrayList和LinkedList区别

  • ArrayList是对象数组实现的,LinkedListed是基于双链表实现的。
  • LinkedList的存储消耗较大,除了存储数据外还要有上下节点的位置。
  • 搜索和读取数的时候前者所花时间比后者小,但插入后者比前者快

2.使用场景:

  1. 如果应用程序对数据有较多的随机访问,ArrayList对象要优于LinkedList对象;
  2. 如果应用程序有更多的插入或者删除操作,较少的随机访问,LinkedList对象要优于ArrayList对象;
  3. 不过ArrayList的插入,删除操作也不一定比LinkedList慢,如果在List靠近末尾的地方插入,那么ArrayList只需要移动较少的数据,而LinkedList则需要一直查找到列表尾部,反而耗费较多时间,这时ArrayList就比LinkedList要快。

3.ArraysList的其他细节

(1)扩容过程
检查数组的大小是否足够,如果不够将创建一个尺寸扩大到1.5倍的新数组(新建时默认初始化长度为10),
将原数组的数据拷贝到新数组中,原数组丢弃,这里会很慢
调用数组方法:
Arrays.copyOf(elementData, newCapacity) ;

(2)多个元素发生移动
remove时:
将指定索引的元素移除是通过数组移动调用
System.arraycopy(elementData, index+1, elementData, index,numMoved);
一次删除会有多个元素发生移动
同理,add(int,E)向一个指定的位置加元素也会发生多个元素移动,

posted @   habc706  阅读(259)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
点击右上角即可分享
微信分享提示