JAVA的ArrayList 和 LinkedList的区别

ArrayList 和 LinkedList 都是 Java 中常用的 List 接口的实现类,主要的区别有:

  1. 底层数据结构不同

-ArrayList 底层使用的是动态数组数据结构,LinkedList 底层使用的是双向链表数据结构。

  1. 获取元素效率不同

ArrayList 支持快速随机访问,通过索引直接获取元素,时间复杂度为 O(1)。

LinkedList需要从头节点开始遍历查找元素,时间复杂度为 O(n)。

  1. 添加删除元素效率不同

ArrayList要移动元素,时间复杂度为 O(n)。

LinkedList只需要改变节点的指针,时间复杂度为 O(1)。

  1. 内存空间占用不同

ArrayList的空间浪费主要在在list列表的结尾会预留一定的容量空间,而LinkedList的空间花费则在每个元素都需要消耗比ArrayList更多的空间(因为要存放直接后继和直接前驱以及数据)。

  1. 线程安全性不同

ArrayList 和 LinkedList 都是非线程安全的,用于多线程环境时需要用

Collections.synchronizedList 方法包装。

所以一般来说,如果需要频繁添加删除元素,使用LinkedList比较好,如果需要频繁随机访问元素,使用ArrayList比较好。

相关推荐
卿雪9 小时前
MySQL【基础】篇:什么是MySQL、主键和外键、三大范式、DDL、DML、DDL、DCL...
java·服务器·开发语言·数据库·后端·mysql·golang
2022.11.7始学前端9 小时前
n8n第二节 实现小卖部商品财务报表自动化生成
java·n8n
y***n6149 小时前
SpringCloud系列教程:微服务的未来(十四)网关登录校验、自定义过滤器GlobalFilter、GatawayFilter
java·spring cloud·微服务
p***s919 小时前
java进阶1——JVM
java·开发语言·jvm
我是苏苏9 小时前
C#基础:如何创建一个类库并且封装成DLL
开发语言·c#
g***96909 小时前
在Nginx上配置并开启WebDAV服务的完整指南
java·运维·nginx
中工钱袋9 小时前
Spring Task 使用指南
java·spring boot·spring
伯远医学9 小时前
CUT&RUN
java·服务器·网络·人工智能·python·算法·eclipse
CryptoRzz9 小时前
如何快速对接印度股票市场 (NSE/BSE) 数据接口
android·java·开发语言·区块链
一晌小贪欢9 小时前
Python-11 Python作用域与闭包:LEGB规则深度解析
开发语言·python·python基础·python小白·python作用域·python小庄