0

0

在Java中LinkedList与ArrayList如何取舍_Java列表结构对比解析

P粉602998670

P粉602998670

发布时间:2026-01-14 20:12:10

|

290人浏览过

|

来源于php中文网

原创

绝大多数日常场景下应优先使用ArrayList,因其CPU缓存友好、随机访问快、内存占用小且JVM优化充分;仅在需高频头尾增删且完全不访问中间索引时才考虑LinkedList。

在java中linkedlist与arraylist如何取舍_java列表结构对比解析

什么时候该用 ArrayList 而不是 LinkedList

绝大多数日常场景下,ArrayList 是更优选择。它底层是动态数组,CPU缓存友好、随机访问快、内存占用小,且现代JVM对数组做了大量优化。

常见适用场景包括:

  • 频繁按索引读取元素(get(i)),比如遍历、查找、分页
  • 批量添加末尾元素(add(e)),扩容摊还成本低(O(1)
  • 需要与数组互转(toArray() / Arrays.asList()
  • 使用 Stream 或第三方库(如 Apache Commons Collections),它们内部多针对数组结构优化

注意:ArrayList 在中间插入/删除(add(i, e) / remove(i))仍是 O(n),但实际性能往往比 LinkedList 的指针操作更快——因为避免了对象分配、GC压力和缓存不命中。

哪些情况真有必要选 LinkedList

LinkedList 唯一不可替代的用途是:需要在**头尾高频增删**,且**完全不访问中间索引**。

立即学习Java免费学习笔记(深入)”;

典型例子:

  • 实现push/popaddFirst()/removeFirst()
  • 实现队列(offer/polladdLast()/removeFirst()
  • 作为双端队列(Deque)参与线程安全的生产者-消费者逻辑(但此时应优先考虑 ConcurrentLinkedQueue

不要因为它“链表”就默认支持快速插入——LinkedList.get(i)O(n) 遍历,比 ArrayList 慢一个数量级。实测在 10k 元素时,随机访问慢 5–10 倍。

MiniMax Agent
MiniMax Agent

MiniMax平台推出的Agent智能体助手

下载

add(index, element) 在两者中的行为差异

表面签名一致,底层代价天差地别:

  • ArrayList.add(i, e):先将索引 i 及之后所有元素右移一位(数组拷贝),再插入;最坏 O(n),但全是连续内存复制,CPU效率高
  • LinkedList.add(i, e):先从头或尾遍历到第 i 个节点(取决于 i 靠近哪端),再修改前后指针;平均 O(n/2),且每次遍历都是非连续内存访问,容易触发缓存失效

尤其当 i 接近中间位置时,LinkedList 不仅没优势,反而更慢。JDK 源码里甚至为 LinkedListget(i) 做了方向优化(从 head 或 tail 走更短路径),但这无法抵消硬件层面的劣势。

内存开销与 GC 影响常被低估

LinkedList 每个元素额外持有两个引用(prevnext),加上对象头、对齐填充,单个节点通常占 24–32 字节;而 ArrayList 的元素直接存入数组,无额外引用开销。

例如存 10 万个 Integer

ArrayList: ~100_000 × 4B (int) + 数组头 ≈ 400KB  
LinkedList: ~100_000 × (24–32B) ≈ 2.4–3.2MB

更大的问题是:LinkedList 创建大量短期存活的小对象(每个节点),加剧 Young GC 频率。在吞吐敏感或内存受限服务中,这点可能成为瓶颈。

真实项目中,除非明确压测证明 LinkedList 在特定操作上胜出,否则默认用 ArrayList;若需高效头尾操作,优先查 ArrayDeque——它用循环数组实现,兼具 ArrayList 的内存效率和 LinkedList 的头尾操作性能。

相关专题

更多
java
java

Java是一个通用术语,用于表示Java软件及其组件,包括“Java运行时环境 (JRE)”、“Java虚拟机 (JVM)”以及“插件”。php中文网还为大家带了Java相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

832

2023.06.15

java正则表达式语法
java正则表达式语法

java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

737

2023.07.05

java自学难吗
java自学难吗

Java自学并不难。Java语言相对于其他一些编程语言而言,有着较为简洁和易读的语法,本专题为大家提供java自学难吗相关的文章,大家可以免费体验。

734

2023.07.31

java配置jdk环境变量
java配置jdk环境变量

Java是一种广泛使用的高级编程语言,用于开发各种类型的应用程序。为了能够在计算机上正确运行和编译Java代码,需要正确配置Java Development Kit(JDK)环境变量。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

397

2023.08.01

java保留两位小数
java保留两位小数

Java是一种广泛应用于编程领域的高级编程语言。在Java中,保留两位小数是指在进行数值计算或输出时,限制小数部分只有两位有效数字,并将多余的位数进行四舍五入或截取。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

398

2023.08.02

java基本数据类型
java基本数据类型

java基本数据类型有:1、byte;2、short;3、int;4、long;5、float;6、double;7、char;8、boolean。本专题为大家提供java基本数据类型的相关的文章、下载、课程内容,供大家免费下载体验。

446

2023.08.02

java有什么用
java有什么用

java可以开发应用程序、移动应用、Web应用、企业级应用、嵌入式系统等方面。本专题为大家提供java有什么用的相关的文章、下载、课程内容,供大家免费下载体验。

430

2023.08.02

java在线网站
java在线网站

Java在线网站是指提供Java编程学习、实践和交流平台的网络服务。近年来,随着Java语言在软件开发领域的广泛应用,越来越多的人对Java编程感兴趣,并希望能够通过在线网站来学习和提高自己的Java编程技能。php中文网给大家带来了相关的视频、教程以及文章,欢迎大家前来学习阅读和下载。

16925

2023.08.03

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

36

2026.01.14

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 2.5万人学习

C# 教程
C# 教程

共94课时 | 6.7万人学习

Java 教程
Java 教程

共578课时 | 45.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号