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。

相关推荐
全靠bug跑1 天前
Spring Cache 实战:核心注解详解与缓存过期时间配置
java·redis·springcache
Swift社区1 天前
LeetCode 465 最优账单平衡
算法·leetcode·职场和发展
聆风吟º1 天前
【数据结构手札】空间复杂度详解:概念 | 习题
java·数据结构·算法
weixin_445054721 天前
力扣热题51
c++·python·算法·leetcode
计算机程序设计小李同学1 天前
基于SpringBoot的个性化穿搭推荐及交流平台
java·spring boot·后端
是一个Bug1 天前
50道核心JVM面试题
java·开发语言·面试
地平线开发者1 天前
linux 常见稳定性问题分析方法
算法·自动驾驶
朱朱没烦恼yeye1 天前
java基础学习
java·python·学习
s砚山s1 天前
代码随想录刷题——二叉树篇(九)
算法
地平线开发者1 天前
大模型常见量化方法简介
算法·自动驾驶