【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 通过链表连接元素,每一个元素都包含前后节点,占用的空间比较大

相关推荐
Inverse1624 分钟前
C语言_自定义类型:结构体
c语言·开发语言·算法
enyp8013 分钟前
Qt原型模式实现与应用
开发语言·qt·原型模式
Musennn19 分钟前
102. 二叉树的层序遍历详解:队列操作与层级分组的核心逻辑
java·数据结构·算法·leetcode
越来越无动于衷25 分钟前
java数组题(5)
java·算法
Mikey_n35 分钟前
Spring Boot 注解详细解析:解锁高效开发的密钥
java·spring boot·后端
CryptoRzz35 分钟前
印度尼西亚数据源对接技术指南
开发语言·python·websocket·金融·区块链
zyx没烦恼38 分钟前
unordered_map和unordered的介绍和使用
开发语言·c++
_yingty_40 分钟前
Java设计模式-策略模式(行为型)
java·设计模式·策略模式
小小寂寞的城1 小时前
Jenkins里构建一个简单流水线
java·运维·jenkins
wowocpp1 小时前
idea springboot 配置文件 中文显示
java·spring boot·intellij-idea