【Java面试题】ArrayList和LinkedList有什么区别

这道题考的是数据结构

ArrayList 和 LinkedList 是 java 集合框架中,list 接口下的两个实现类。

以下从三个方面来讲述ArrayList 和 LinkedList 的区别

目录

[1. 内部的实现方面](#1. 内部的实现方面)

[2. 数据访问的时间复杂度不同](#2. 数据访问的时间复杂度不同)

3.空间占用方面


1. 内部的实现方面

ArrayList 内部使用的是数组的实现,通过索引来访问元素,支持快速随机访问。

LinkeList 内部使用的是双向链表来实现,每一个元素都包含一个指向前一个元素

和后一个元素的引用,适合插入和删除等操作。

2. 数据访问的时间复杂度不同

ArrayList 的时间复杂度是 O(1)

LinkedList 的时间复杂度为 O(n),是因为LinkedList 需要从头部或者尾部开始链表

直到找到元素的位置。

3.空间占用方面

ArrayList 使用数组来存储数据,占用的空间是连续的。

为何占用的空间是连续的?

可以参考:ArrayList 的自动扩容机制

https://blog.csdn.net/m0_67930426/article/details/134388002

LinkedList 通过链表连接元素,每一个元素都包含前后节点,占用的空间比较大

相关推荐
gelald6 分钟前
SpringBoot - 自动配置原理
java·spring boot·后端
殷紫川7 分钟前
深入理解 AQS:从架构到实现,解锁 Java 并发编程的核心密钥
java
一轮弯弯的明月11 分钟前
贝尔数求集合划分方案总数
java·笔记·蓝桥杯·学习心得
chenjingming66616 分钟前
jmeter线程组设置以及串行和并行设置
java·开发语言·jmeter
殷紫川21 分钟前
深入拆解 Java volatile:从内存屏障到无锁编程的实战指南
java
eddieHoo28 分钟前
查看 Tomcat 的堆内存参数
java·tomcat
cch891828 分钟前
Python主流框架全解析
开发语言·python
那个失眠的夜29 分钟前
Mybatis延迟加载策略
xml·java·数据库·maven·mybatis
不爱吃炸鸡柳32 分钟前
C++ STL list 超详细解析:从接口使用到模拟实现
开发语言·c++·list
十五年专注C++开发37 分钟前
RTTR: 一款MIT 协议开源的 C++ 运行时反射库
开发语言·c++·反射