ArrayList和LinkedList的区别

  1. **底层数据结构**:ArrayList基于动态数组实现,内部维护一个Object数组,默认初始容量为10,当元素数量超过当前容量会自动扩容

  2. **随机访问效率高**:基于数组,ArrayList通过索引访问元素,时间复杂度为O(1)

  3. **插入和删除效率低**:在中间或开头插入/删除元素时,需要移动后续元素,时间复杂度为O(n)

  4. **适合随机访问**:对于频**繁随机访问元素**的场景,ArrayList性能更好

LinkedList

  1. **底层数据结构**:LinkedList基于双向链表实现,每个节点包含数据元素和指向前后节点的引用

  2. **插入和删除效率高**:在任意位置插入/删除元素时,只需要调节相邻节点的引用,时间复杂度为O(1)

  3. **顺序访问效率低**:由于基于链表,不能随机访问,需要从头到尾开始遍历,时间复杂度为O(n)

  4. **适合频繁插入和删除**:对于频繁插入和删除的场景,效果更好

特殊情况

头插法插入数据:

​ AarrayList需要将元素依次向后移动,时间复杂度为O(n);

​ LinkedList只需要调整指针,时间复杂度为O(1)

**<u>*尾插法*</u>**插入数据:

​ ArrayList在尾部插入元素的时间复杂度为 O(1)

​ LinkedList在尾部插入元素也是O(1)

两者尾插法 都一样的效率

相同

  • 不同步

  • 线程不安全

  • 但是效率高

相关推荐
Derek_Smart1 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP2 小时前
MyBatis-mybatis入门与增删改查
java
孟陬6 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
想用offer打牌6 小时前
一站式了解四种限流算法
java·后端·go
华仔啊6 小时前
Java 开发千万别给布尔变量加 is 前缀!很容易背锅
java
也些宝7 小时前
Java单例模式:饿汉、懒汉、DCL三种实现及最佳实践
java
Nyarlathotep01137 小时前
SpringBoot Starter的用法以及原理
java·spring boot
wuwen58 小时前
WebFlux + Lettuce Reactive 中 SkyWalking 链路上下文丢失的修复实践
java
SimonKing8 小时前
GitHub 10万星的OpenCode,正在悄悄改变我们的工作流
java·后端·程序员