ArrayList与LinkedList的区别

1.底层实现不同

ArrayList底层是动态数组实现的。

LinkedList底层是双向链表实现的。

2.操作数据的效率

ArrayList可以按照下标查询,时间复杂度为O(1)。而LinkedList不支持下标查询。

查找的话二者都是需要遍历的,所以时间复杂度都是O(n)。

新增和删除:

ArrayList头尾插入和删除都是O(1),对于其他部位修改都需要移动数组所以是O(n)。

LinkedList头尾也是O(1),其他部位插入和删除需要遍历链表,所以O(n)。

3.内存空间占用

ArrayList底层是数组,内存连续,省空间。

LinkedList底层是双向链表,需要存储一个数据两个指针,更占用内存。

4.线程安全

两者都不是线程安全的。

如何保证线程安全:

在方法内使用局部变量。(因为局部变量是存放在栈帧里的,每个线程有一个栈,他们是线程不共享的)

使用线程安全的ArrayList和LinkedList。

相关推荐
wb0430720119 小时前
从 Java 1 到 Java 26 的HTTP Client发展历程
java·开发语言·http
fu159357456819 小时前
【使用python代码制作数学逻辑动画】 ——【教程】
开发语言·python
小则又沐风a19 小时前
进一步了解进程---第四章 进程管理
java·服务器·前端
超梦dasgg19 小时前
并查集(Union-Find)详解 + Java 完整实现
java·数据结构·算法·图搜索
WL_Aurora19 小时前
Java集合框架核心组件
java
Shadow(⊙o⊙)19 小时前
Linux基础IO-1.0——open、close、read及write-深入手搓分析!
linux·运维·服务器·开发语言·c++·学习
我是一颗柠檬19 小时前
【JDK8新特性】Stream流API上Day4
java·开发语言·后端
超梦dasgg19 小时前
拆分大对象 + 流式处理 + 不一次性加载全量数据
java·jvm·windows
A南方故人19 小时前
将容器内的元素变为可拖拽
开发语言·javascript·ecmascript
小小de风呀19 小时前
de风——【从零开始学C++】(九)—vector的基本使用
开发语言·c++