当前位置: 首页 > article >正文

Java面试必问:ArrayList 和 LinkedList 区别:从底层到实战,彻底搞懂

ArrayList 和 LinkedList 区别从底层到实战彻底搞懂面试官“ArrayList 和 LinkedList 有什么区别”你“ArrayList 底层是动态数组查询快、增删慢LinkedList 底层是双向链表增删快、查询慢。”面试官“那如果我在链表中间插入元素真的是 O(1) 吗”你“……”很多人的回答止步于表面但面试官追问的往往是细节。本文从源码到内存、从理论到陷阱彻底讲透这两个集合的区别。一、一句话对比背诵版维度ArrayListLinkedList底层结构动态数组Object[]双向链表Node 节点查询效率O(1)随机访问快O(n)需遍历增删效率尾部 O(1)中间 O(n)头尾 O(1)中间 O(n)内存占用连续内存有闲置空间分散内存每个节点额外存储前后指针使用场景读多写少写多读少尤其是头尾操作二、底层结构详解1. ArrayList动态数组// JDK 8 源码简化publicclassArrayListE{transientObject[]elementData;// 存储元素的数组privateintsize;// 实际元素个数}初始容量为 10懒加载add 时才创建扩容newCapacity oldCapacity (oldCapacity 1)→ 1.5 倍扩容元素在内存中连续存放通过下标访问极快。2. LinkedList双向链表// JDK 8 源码简化publicclassLinkedListE{transientNodeEfirst;// 头节点transientNodeElast;// 尾节点privatestaticclassNodeE{Eitem;NodeEnext;NodeEprev;}}每个节点独立存在通过 prev/next 指针连接。没有扩容概念随增随加。三、增删效率的真实面目很多人背“LinkedList 增删快 O(1)”这是不严谨的。1. 头尾操作确实是 O(1)linkedList.addFirst(e);// 直接修改 first 指针linkedList.addLast(e);// 直接修改 last 指针linkedList.removeFirst();linkedList.removeLast();2. 中间插入O(n) 定位 O(1) 改指针// 在 index 处插入元素linkedList.add(index,element);源码中会先通过node(index)遍历到该位置NodeEnode(intindex){if(index(size1)){NodeExfirst;for(inti0;iindex;i)xx.next;returnx;}else{NodeExlast;for(intisize-1;iindex;i--)xx.prev;returnx;}}遍历耗时 O(n)真正改指针只是 O(1)。所以中间增删总复杂度也是 O(n)和 ArrayList 的 O(n) 没有量级差别只是常数不同ArrayList 需要复制元素LinkedList 只需改指针。结论只有头尾增删LinkedList 才有真正的 O(1) 优势。四、查询效率ArrayList 完胜arrayList.get(10000);// 直接返回 elementData[10000] → O(1)linkedList.get(10000);// 从 first 或 last 遍历 10000 步 → O(n)所以随机读取场景ArrayList 碾压 LinkedList。五、内存占用对比ArrayList数组本身是连续内存但可能预留了闲置空间例如 size10capacity15。每个元素只是一个引用4 或 8 字节无额外指针。LinkedList每个节点前驱指针 后继指针 元素引用 ≈ 24 字节额外开销64位 JVM 默认压缩指针下。节点在内存中分散CPU 缓存不友好遍历时 cache miss 率高。结论LinkedList 内存占用明显高于 ArrayList。六、使用场景与误区正确场景场景推荐频繁随机访问读多写少ArrayList频繁头尾增删如队列、栈LinkedList或 ArrayDeque 更优频繁中间增删两者都是 O(n)但 LinkedList 常数更小可酌情使用常见误区“LinkedList 增删总是比 ArrayList 快”→ 错。中间增删都需要先定位ArrayList 在尾部增删甚至更快。“LinkedList 实现了 Queue所以做队列最好”→ 不完全是。ArrayDeque在大多数场景下比 LinkedList 更快、更省内存。“ArrayList 扩容很慢所以能用 LinkedList 就用”→ 过度担忧。扩容均摊后仍是 O(1)且现代 JVM 内存分配很快。七、实战建议1. 写代码时如何选择// 已知元素数量或者以随机访问为主ListIntegerlistnewArrayList();// 需要频繁在头尾操作且元素数量很大QueueIntegerqueuenewLinkedList();// 或者 ArrayDeque// 不确定先用 ArrayList遇到性能瓶颈再分析2. 性能测试小例子// 头部插入 10 万次longstartSystem.currentTimeMillis();ListIntegerlistnewArrayList();for(inti0;i100000;i){list.add(0,i);// 每次移动全部元素}System.out.println(ArrayList head insert: (System.currentTimeMillis()-start)ms);// LinkedList 头部插入listnewLinkedList();startSystem.currentTimeMillis();for(inti0;i100000;i){list.add(0,i);// 只改指针}System.out.println(LinkedList head insert: (System.currentTimeMillis()-start)ms);结果典型值ArrayList~2000msLinkedList~5ms八、总结一张表特性ArrayListLinkedList底层数组双向链表随机访问 get/setO(1)O(n)尾部增删O(1) 均摊O(1)头部增删O(n)O(1)中间增删O(n) 移动O(n) 改指针内存连续性连续分散额外内存少量预留空间较大节点指针迭代性能好局部性差指针跳跃终极建议默认用ArrayList。只有确定需要大量头尾操作且不需要随机访问时再考虑LinkedList或更优的ArrayDeque。永远不要为了“听说增删快”而在中间插入场景盲目使用 LinkedList。希望这篇文章能帮你彻底掌握 ArrayList 与 LinkedList 的区别面试时从容应对追问。

相关文章:

Java面试必问:ArrayList 和 LinkedList 区别:从底层到实战,彻底搞懂

ArrayList 和 LinkedList 区别:从底层到实战,彻底搞懂面试官:“ArrayList 和 LinkedList 有什么区别?” 你:“ArrayList 底层是动态数组,查询快、增删慢;LinkedList 底层是双向链表,…...

【Shell专项】数组与函数的使用

第四章 数组和函数4.1 数组 4.1.1 简介 变量:用一个固定的字符串,代替一个不固定字符串。数组:用一个固定的字符串,代替多个不固定字符串。 4.1.2 类型 普通数组:只能使用整数作为数组索引关联数组:可以使用…...

ICLR 2026 Oral | Q-RAG:当大家都在训练大模型学会搜索,它却选择训练检索器

最近看到一篇很有意思的工作:Q-RAG: Long Context Multi-Step Retrieval via Value-Based Embedder Training。 这篇论文最吸引我的地方,不是它又做了一个“更复杂的 Agent RAG”,而是它提出了一个非常反直觉、但又非常实用的思路: 当很多工作都在强化学习微调 LLM,让大模…...

从零搭建高安全低代码表单系统,手把手实现JWT动态权限校验+防CSRF提交+审计日志闭环,7天交付标准SaaS组件

第一章:从零构建高安全低代码表单系统概览 高安全低代码表单系统并非传统表单引擎的简单封装,而是融合身份鉴权、字段级加密、动态权限策略与不可篡改审计能力的一体化平台。其核心目标是在显著降低前端开发门槛的同时,满足金融、政务等强监管…...

【Day 10 Java转Python】@property——把方法当属性用,Python的封装艺术

Java老兵写Python时最常问的问题:“私有字段呢?getter和setter呢?没有这些,封装还叫封装吗?” 别急,Python告诉你:封装不是为了写一堆getXxx()/setXxx(),而是为了在需要时优雅地插入…...

华中科技大学本科毕业论文LaTeX模板完整使用指南:快速上手终极教程

华中科技大学本科毕业论文LaTeX模板完整使用指南:快速上手终极教程 【免费下载链接】HUSTPaperTemp 华中科技大学本科毕业论文LaTeX模板 2017 项目地址: https://gitcode.com/gh_mirrors/hu/HUSTPaperTemp 对于华中科技大学的本科生来说,毕业论文…...

Ofd2Pdf完整指南:3种高效方法实现OFD到PDF的无损转换

Ofd2Pdf完整指南:3种高效方法实现OFD到PDF的无损转换 【免费下载链接】Ofd2Pdf Convert OFD files to PDF files. 项目地址: https://gitcode.com/gh_mirrors/ofd/Ofd2Pdf OFD(Open Fixed-layout Document)作为我国自主研发的电子文档…...

openclaw平替之nanobot源码解析(七):Gateway与多渠道集成腾

背景 StreamJsonRpc 是微软官方维护的用于 .NET 和 TypeScript 的 JSON-RPC 通信库,以其强大的类型安全、自动代理生成和成熟的异常处理机制著称。在 HagiCode 项目中,为了通过 ACP (Agent Communication Protocol) 与外部 AI 工具(如 iflow …...

CAGE vs RNA-seq:两种转录组测序技术的深度对比

在选择转录组测序方案时,你是否也在 CAGE 和 RNA-seq 之间犹豫?本文带你深入了解两种技术的核心差异与各自优势。转录组测序是功能基因组学研究的核心技术。在众多技术中,CAGE(Cap Analysis of Gene Expression)和RNA-…...

终极指南:如何免费使用Cursor Pro AI编程助手完整教程

终极指南:如何免费使用Cursor Pro AI编程助手完整教程 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve reached your tri…...

终极命令行工具:如何用BaiduPCS-Go高效管理百度网盘文件

终极命令行工具:如何用BaiduPCS-Go高效管理百度网盘文件 【免费下载链接】BaiduPCS-Go iikira/BaiduPCS-Go原版基础上集成了分享链接/秒传链接转存功能 项目地址: https://gitcode.com/GitHub_Trending/ba/BaiduPCS-Go 在当今数据驱动的时代,高效…...

跨境电商研发团队文件外发安全管控

我有个朋友在深圳做跨境电商,主要卖智能家居产品到北美。上个月他跟我说了件差点让他丢大客户的事—— 他们的研发文件从来都是"谁需要找谁要",邮件、微信、U盘,什么渠道都有。有一天,研发部把一批新款智能锁的固件代码…...

Mem Reduct终极指南:三步解决电脑卡顿,高效释放内存空间

Mem Reduct终极指南:三步解决电脑卡顿,高效释放内存空间 【免费下载链接】memreduct Lightweight real-time memory management application to monitor and clean system memory on your computer. 项目地址: https://gitcode.com/gh_mirrors/me/memr…...

10分钟训练高质量AI音色:RVC变声器实战指南

10分钟训练高质量AI音色&#xff1a;RVC变声器实战指南 【免费下载链接】Retrieval-based-Voice-Conversion-WebUI Easily train a good VC model with voice data < 10 mins! 项目地址: https://gitcode.com/GitHub_Trending/re/Retrieval-based-Voice-Conversion-WebUI …...

Anaconda Navigator打不开?三步搞定‘str‘ object has no attribute ‘get‘报错(附详细文件修改指南)

Anaconda Navigator启动报错深度修复指南&#xff1a;从原理到实战 当你满心期待地双击Anaconda Navigator图标&#xff0c;准备开始一天的数据分析工作&#xff0c;却迎面撞上"str object has no attribute get"这个晦涩的错误提示——这种挫败感我太熟悉了。作为P…...

Mi-Create:小米手表表盘设计的终极免费工具完整指南

Mi-Create&#xff1a;小米手表表盘设计的终极免费工具完整指南 【免费下载链接】Mi-Create Unofficial watchface creator for Xiaomi wearables ~2021 and above 项目地址: https://gitcode.com/gh_mirrors/mi/Mi-Create 还在为小米手表找不到心仪表盘而烦恼吗&#x…...

终极电路设计解决方案:如何用Draw.io ECE库高效绘制专业电路图

终极电路设计解决方案&#xff1a;如何用Draw.io ECE库高效绘制专业电路图 【免费下载链接】Draw-io-ECE Custom-made draw.io-shapes - in the form of an importable library - for drawing circuits and conceptual drawings in draw.io. 项目地址: https://gitcode.com/g…...

BepInEx完整指南:3步掌握Unity游戏插件注入技术

BepInEx完整指南&#xff1a;3步掌握Unity游戏插件注入技术 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx BepInEx是一个功能强大的Unity游戏插件框架&#xff0c;专为Mono、IL2C…...

团队协作痛点怎么破?高安全性与高性价比企业云盘深度对比

近日&#xff0c;众多小微企业、创业团队与个人工作室在寻求高效协同工具时迎来了利好——随着2026年企业级SaaS市场的进一步成熟&#xff0c;以坚果云为代表的高性能企业网盘正以极高的性价比和专业度&#xff0c;解决着企业“数据安全与便捷协作”两大核心痛点。 为了帮助企…...

HoRain云--Flask中间件与扩展全解析

&#x1f3ac; HoRain云小助手&#xff1a;个人主页 &#x1f525; 个人专栏: 《Linux 系列教程》《c语言教程》 ⛺️生活的理想&#xff0c;就是为了理想的生活! ⛳️ 推荐 前些天发现了一个超棒的服务器购买网站&#xff0c;性价比超高&#xff0c;大内存超划算&#xff01;…...

跨平台协作:Windows主机+Mac笔记本共享Qwen3.5-9B实例

跨平台协作&#xff1a;Windows主机Mac笔记本共享Qwen3.5-9B实例 1. 项目背景与需求 去年开始使用OpenClaw进行个人自动化任务时&#xff0c;我遇到了一个典型的多设备协同问题&#xff1a;主力开发机是Windows台式机&#xff08;32GB内存RTX 3090&#xff09;&#xff0c;但…...

PyTorch 2.8虚拟机开发环境:VMware中配置Ubuntu并连接云端GPU

PyTorch 2.8虚拟机开发环境&#xff1a;VMware中配置Ubuntu并连接云端GPU 1. 为什么选择这种开发方式&#xff1f; 对于深度学习开发者来说&#xff0c;本地开发环境配置往往是个头疼的问题。特别是当你的笔记本显卡性能有限&#xff0c;又不想完全依赖云端开发时&#xff0c…...

【AI原生开发范式革命指南】:20年架构师亲授从Spring Boot到LLM-Ops的5大跃迁路径

第一章&#xff1a;从传统开发到AI原生&#xff1a;软件研发范式革命 2026奇点智能技术大会(https://ml-summit.org) 软件研发正经历一场静默却深刻的范式迁移——从以人类编写确定性逻辑为核心的传统工程模式&#xff0c;转向以提示工程、模型调用与反馈闭环为基座的AI原生架…...

Kandinsky-5.0-I2V-Lite-5s环境部署详解:JDK与依赖库的完整安装配置

Kandinsky-5.0-I2V-Lite-5s环境部署详解&#xff1a;JDK与依赖库的完整安装配置 1. 准备工作 在开始部署Kandinsky-5.0-I2V-Lite-5s之前&#xff0c;我们需要确保服务器具备运行该模型所需的基础环境。这个由文本生成视频的AI模型需要特定的Java运行环境和视频处理工具才能正…...

3步解放你的华硕笔记本:G-Helper轻量控制工具完全指南

3步解放你的华硕笔记本&#xff1a;G-Helper轻量控制工具完全指南 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, Flow, TUF, Strix, Sc…...

League Akari:如何让英雄联盟游戏体验更智能高效?

League Akari&#xff1a;如何让英雄联盟游戏体验更智能高效&#xff1f; 【免费下载链接】League-Toolkit An all-in-one toolkit for LeagueClient. Gathering power &#x1f680;. 项目地址: https://gitcode.com/gh_mirrors/le/League-Toolkit 您是否曾经在英雄联盟…...

千问3.5-9B MATLAB科学计算辅助:算法解释与代码转换

千问3.5-9B MATLAB科学计算辅助&#xff1a;算法解释与代码转换 1. 为什么MATLAB用户需要AI助手 MATLAB在科学计算领域占据重要地位&#xff0c;但工程师和研究人员经常面临两个核心痛点&#xff1a;理解复杂算法原理的困难&#xff0c;以及跨平台代码迁移的繁琐。传统方式下…...

再次革新 .NET 的构建和发布方式(三)僚

1 安装与初始化 # 全局安装 OpenSpec npm install -g fission-ai/openspeclatest # 在项目目录下初始化 cd /path/to/your-project openspec init 初始化时&#xff0c;OpenSpec 会提示你选择使用的 AI 工具&#xff08;Claude Code、Cursor、Trae、Qoder 等&#xff09;。 3 O…...

2026年AI应用开发完整路线:Java后端+Python大模型,少走2年弯路

文章强调AI应用开发需Java后端与Python并重&#xff0c;78%企业招聘要求Java后端知识。提供三条学习路线&#xff1a;Java后端基础、Java AI进阶、Python大模型实战。针对不同人群给出精准建议&#xff0c;指出跳过后端直接学Python是最大误区。掌握JavaPython的复合型工程师薪…...

软考高项通关秘籍:手把手教你用Excel打造需求跟踪矩阵(附模板下载)

软考高项实战指南&#xff1a;用Excel构建需求跟踪矩阵的7个关键步骤 在项目管理领域&#xff0c;需求跟踪矩阵就像是一张精准的导航地图&#xff0c;它能确保项目团队从需求源头到最终交付物始终保持正确的航向。对于备考软考高项&#xff08;信息系统项目管理师&#xff09;的…...