java八股文面试[数据结构]——ArrayList和LinkedList区别

ArrayList和LinkedList的异同

二者的线程都不安全,相对线程安全的Vector,执行效率高。此外,ArrayList时实现了基于动态数组的数据结构,LinkedList基于链表的数据结构,对于随机访问get和set,ArrayList觉得优于LinkedList比较占优势,因为LinledList要移动指针。对于新增和删除操作add(特指插入)和remove,LinkedList比较占优势,因为ArrayList要移动数据。

ArrayList和Vector的区别

Vector和ArrayList几乎是完全相同的,唯一的区别在于Vector是同步类(synchronized) ,属于强同步类,因为开销就比ArrayList要大,访问要慢。正常情况下,大多数的java程序员使用ArrayList而不是Vector,因为同步完全可以由程序员自己来控制。Vector每次扩容请求其大小的2倍 空间,而ArrayList是1.5倍

ArrayList 的源码分析

结论:建议开发中使用带参的构造器 :ArrayList list=new ArrayList(int capacity)

Jdk8中ArrayList的变化

LinkedList 的源码分析

数据结构实现 : ArrayList 是动态数组的数据结构实现,而 LinkedList 是双向链表的数据结构实

现。
随机访问效率 : ArrayList 比 LinkedList 在随机访问的时候效率要高,因为 LinkedList 是线性的数

据存储方式,所以需要移动指针从前往后依次查找。
增加和删除效率 :在非首尾的增加和删除操作, LinkedList 要比 ArrayList 效率要高,因为

ArrayList 增删操作要影响数组内的其他数据的下标。
内存空间占用 : LinkedList 比 ArrayList 更占内存,因为 LinkedList 的节点除了存储数据,还存储

了两个引用,一个指向前一个元素,一个指向后一个元素。
线程安全 : ArrayList 和 LinkedList 都是不同步的,也就是不保证线程安全;

综合来说,在需要频繁读取 集合中的元素时,更推荐使用 ArrayList ,而在插入和删除 操作较多

时,更推荐使用 LinkedList 。

LinkedList 的双向链表也叫双链表 ,是链表的一种,它的每个数据结点中都有两个指针,分别指向

直接后继和直接前驱。所以,从双向链表中的任意一个结点开始,都可以很方便地访问它的前驱结
点和后继结点

知识来源:

【基础】ArrayList和LinkedList区别_哔哩哔哩_bilibili

【2023年面试】ArrayList和LinkedList有什么区别_哔哩哔哩_bilibili

Java中的集合框架_java集合框架_汝甚骚吾不及的博客-CSDN博客

JAVA集合面试题52道_秋枫要学习的博客-CSDN博客

相关推荐
石榴树下的七彩鱼6 分钟前
医疗票据 OCR 识别 API 多场景落地指南:医保结算 + 商保理赔 + 医疗信息化(附 Python/Java 完整示例)
java·python·ocr·石榴智能·医疗票据ocr·医保结算·ocrapi
C137的本贾尼11 分钟前
Spring AI Alibaba 开箱:国产百炼大模型初体验
java·人工智能·spring
啊董dong28 分钟前
noi-2026年5月12号小测验
数据结构·c++·算法
金銀銅鐵42 分钟前
[Java] 如何理解 class 文件中字段的 access flags?
java·后端
小短腿的代码世界1 小时前
Qt国际化深度解析:从源码到企业级多语言实践
java·数据库·qt
凌冰_1 小时前
IDEA 集成Claude Code
java·ide
SXJR1 小时前
Java中的Cross-Encoder模型解决方案
java·开发语言
南境十里·墨染春水1 小时前
数据结构 —— 链表
数据结构·链表
彦为君1 小时前
JavaSE-11-BIO/NIO/AIO(多人聊天室)
java·开发语言·python·ai·nio
Cosolar1 小时前
收藏备用!2026 年所有主流 RAG 开源项目都在这里了
人工智能·面试·llm