LinkedeList和ArrayList都实现了List接口,但是它们的工作原理却不一样。它们之间最主要的区别在于ArrayList是可改变大小的数组,而LinkedList是双向链接串列(doubly LinkedList)。ArrayList更受欢迎,很多场景下ArrayList比LinkedList更为适用。这篇文章中我们将会看看LinkedeList和ArrayList的不同,而且我们试图来看看什么场景下更适宜使用LinkedList,而不用ArrayList。

LinkedList和ArrayList的区别

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

什么场景下更适宜使用LinkedList,而不用ArrayList

我前面已经提到,很多场景下ArrayList更受欢迎,但是还有些情况下LinkedList更为合适。譬如:

1) 你的应用不会随机访问数据。因为如果你需要LinkedList中的第n个元素的时候,你需要从第一个元素顺序数到第n个数据,然后读取数据。

2) 你的应用更多的插入和删除元素,更少的读取数据。因为插入和删除元素不涉及重排数据,所以它要比ArrayList要快。

以上就是关于ArrayList和LinkedList的差别。你需要一个不同步的基于索引的数据访问时,请尽量使用ArrayList。ArrayList很快,也很容易使用。但是要记得要给定一个合适的初始大小,尽可能的减少更改数组的大小。

最新文章

  1. Canvas里绘制矩阵文字
  2. C# UDP 连接通信 简单示例
  3. 架设证书服务器 及 让IIS启用HTTPS服务(转)
  4. 1. windows环境安装Node.js
  5. VTK三维重建(1)-使用VTK读取DICOM,并动态输出
  6. Xcode-程序开发设计-01UIKit 框架
  7. jquery dragsort table实现拖拽排序
  8. Com进程通信(有详细步骤)
  9. android——ImageLoader添加缓存
  10. 字符串转换为整数”123“->123
  11. Elasticsearch集群调优
  12. 微信公众号批量爬取java版
  13. linkin大话设计模式--观察者模式
  14. CSS 选择器简介
  15. Bootstrap简单HelloWorld入门教程
  16. engineercms支持文档协作和文档流程,基于flow
  17. postgresql的基本使用,以及数据库的备份与恢复
  18. flink-vs.-spark
  19. [转载]JDBC/Spring/MyBatis性能比较
  20. python socket编程函数介绍

热门文章

  1. Maven自动FTP远程部署
  2. C 扩展库 - mysql API CRUD
  3. linux centos 7.5 安装mysql5.7
  4. golang reflect包使用解析
  5. linux下统计文本行数的各种方法(一)
  6. OC基础之访问修饰符
  7. [转]OData的初步认识 OData v4 Client Code Generator
  8. td 不换行 隐藏显示多余的部分(转)
  9. SQL Serever学习11——数据库的安全管理
  10. SQL SERVER2014的安装