0

0

Java面试——ArrayList与LinkedList的区别及选型

幻夢星雲

幻夢星雲

发布时间:2026-01-18 06:31:21

|

360人浏览过

|

来源于php中文网

原创

arraylist随机访问快(o(1)),但中间插入/删除慢(o(n));linkedlist头尾增删快(o(1)),但随机访问慢(o(n));选型需结合实际操作模式,而非仅看理论复杂度。

java面试——arraylist与linkedlist的区别及选型

ArrayList 随机访问快,但中间插入/删除慢

因为 ArrayList 底层是动态数组,支持通过下标直接定位元素,get(int index)O(1) 时间复杂度。但一旦在中间位置调用 add(int index, E element)remove(int index),就要把后续所有元素整体拷贝移动,最坏是 O(n)

常见错误:用 ArrayList 在循环中反复 remove() 满足条件的元素,没注意索引偏移,导致漏删或 IndexOutOfBoundsException;或者误以为 list.add(0, x) 很便宜,实际每次都在头部插入,性能急剧下降。

  • 适合场景:读多写少、频繁按索引查值、需要 Arrays.binarySearch()Collection.toArray() 的场合
  • 注意扩容:初始容量默认是 10,触发扩容时会新建数组并 System.arraycopy(),有额外开销;若已知大致大小,建议构造时传入 initialCapacity
  • 线程不安全:多线程环境下直接使用会出错,别指望“偶尔跑一次没问题”

LinkedList 插入删除快,但随机访问极慢

LinkedList 是双向链表实现,addFirst()addLast()removeFirst()removeLast() 全是 O(1);在已有 ListIterator 位置附近增删也是 O(1)。但它的 get(int index) 必须从头或尾开始遍历指针,平均 O(n/2),比 ArrayList 慢一个数量级。

很多人以为 “LinkedList 适合频繁增删”,却忽略了前提:必须是头尾操作,或已有迭代器定位点。用 list.get(i)remove(i) 实际是两次遍历,比 ArrayList 还慢。

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

Dreamhouse AI
Dreamhouse AI

AI室内设计,快速重新设计你的家,虚拟布置家具

下载
  • 适合场景:当逻辑天然符合队列(offer()/poll())、push()/pop())或需在遍历中动态增删(配合 ListIterator)时才真正受益
  • 内存开销大:每个元素额外存两个指针(prevnext),对象头+引用本身比数组元素占用多 50% 以上内存
  • 不支持快速随机访问:subList() 返回的是 SubList 视图,但底层仍是链表遍历,不是切片优化

选型不能只看“理论复杂度”,得看真实操作模式

面试常问“什么情况选哪个”,但真实项目里,多数人卡在“根本没想清楚自己在做什么操作”。比如:

  • for (int i = 0; i —— 这是典型误用,无论 <code>ArrayList 还是 LinkedList 都很糟糕;正确做法是用 Iterator.remove()removeIf()
  • 需要频繁按条件查找后删除:先用 Stream.filter() 收集新列表,比原地删更清晰且往往更快
  • 数据量小(LinkedList,要当数组就用 ArrayList
  • 若真需要头尾高效 + 随机访问,考虑 ArrayDeque(非 List 实现,但比 LinkedList 更省内存、缓存友好)

别忽略替代方案:Vector、CopyOnWriteArrayList、Collections.synchronizedList

面试可能延伸问线程安全。记住:Vector 是历史遗留类,所有方法加了 synchronized,但锁粒度太粗,实际并发性能差;CopyOnWriteArrayList 适合读远多于写的场景(如监听器列表),但每次写都复制整个数组,大数据量写操作代价极高;Collections.synchronizedList(new ArrayList()) 只是对单个方法加锁,复合操作(如先 size()get())仍需手动同步。

真正高并发场景,通常应跳过这些 List,改用 ConcurrentHashMap 模拟集合,或用 java.util.concurrent 下更合适的结构(如 ConcurrentLinkedQueue)。

List<String> safeList = Collections.synchronizedList(new ArrayList<>());
// 下面这段仍然不是线程安全的!
if (safeList.size() > 0) {
    String first = safeList.get(0); // 中间可能被其他线程清空
}

链表和数组的选择,本质是时间与空间、局部性与灵活性的权衡。很多人死记“ArrayList 查快、LinkedList 增删快”,却忘了现代 CPU 缓存对连续内存的偏好——哪怕 ArrayList 删除要搬动数据,只要数组不大,也常常比 LinkedList 遍历几十个分散对象更快。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

841

2023.08.22

string转int
string转int

在编程中,我们经常会遇到需要将字符串(str)转换为整数(int)的情况。这可能是因为我们需要对字符串进行数值计算,或者需要将用户输入的字符串转换为整数进行处理。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

950

2023.08.02

int占多少字节
int占多少字节

int占4个字节,意味着一个int变量可以存储范围在-2,147,483,648到2,147,483,647之间的整数值,在某些情况下也可能是2个字节或8个字节,int是一种常用的数据类型,用于表示整数,需要根据具体情况选择合适的数据类型,以确保程序的正确性和性能。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

604

2024.08.29

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

294

2025.08.29

C++中int的含义
C++中int的含义

本专题整合了C++中int相关内容,阅读专题下面的文章了解更多详细内容。

212

2025.08.29

堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

434

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

600

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

743

2023.08.10

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

19

2026.03.05

热门下载

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

精品课程

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

共23课时 | 4.1万人学习

C# 教程
C# 教程

共94课时 | 10.7万人学习

Java 教程
Java 教程

共578课时 | 77.6万人学习

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

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