ArrayList和LinkedList的区别

  1. 底层数据结构
  • ArrayList 是动态数组的数据结构实现。

  • LinkedList 是双向链表的数据结构实现。

  1. 操作数据效率
  • ArrayList按照下标查询的时间复杂度O(1)【内存是连续的,根据寻址公式】, LinkedList不支持下标查询。

  • 查找(未知索引): ArrayList需要遍历,链表也需要链表,时间复杂度都是O(n)。

  • 新增和删除

    • ArrayList尾部插入和删除,时间复杂度是O(1);其他部分增删需要挪动数组,时间复杂度是O(n)。

    • LinkedList头尾节点增删时间复杂度是O(1),其他都需要遍历链表,时间复杂度是O(n)。

  1. 内存空间占用
  • ArrayList底层是数组,内存连续,节省内存。

  • LinkedList 是双向链表需要存储数据,和两个指针,更占用内存。

  1. 线程安全
  • ArrayList和LinkedList都不是线程安全的。

  • 如果需要保证线程安全,有两种方案:

    • 在方法内使用,局部变量则是线程安全的。

    • 使用线程安全的ArrayList和LinkedList。

相关推荐
怕浪猫43 分钟前
Electron 系列文章封面图
算法·架构·前端框架
plainGeekDev1 小时前
null 判断 → Kotlin 可空类型
android·java·kotlin
糖拌西瓜皮1 小时前
Java开发者视角:深入理解Node.js异步编程模型
java·后端·node.js
plainGeekDev1 小时前
getter/setter → Kotlin 属性
android·java·kotlin
一线大码1 小时前
Smart-Doc 的简单使用
java·后端·restful
假如让我当三天老蒯2 小时前
回归基本功!前端的解构赋值、扩展运算符、剩余参数
前端·面试
Lee川2 小时前
Memory 模块深度解析(面试向)
人工智能·面试
MacroZheng3 小时前
Claude Code官方桌面端正式发布,夯爆了!
java·人工智能·后端
虚无境3 小时前
如何编写一个SpringBoot项目告警推送的Starter
java·prometheus·webhook