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)

两者尾插法 都一样的效率

相同

  • 不同步

  • 线程不安全

  • 但是效率高

相关推荐
roman_日积跬步-终至千里26 分钟前
【LangGraph4j】LangGraph4j 核心概念与图编排原理
java·服务器·数据库
野犬寒鸦1 小时前
从零起步学习并发编程 || 第六章:ReentrantLock与synchronized 的辨析及运用
java·服务器·数据库·后端·学习·算法
wenzhangli71 小时前
ooderA2UI BridgeCode 深度解析:从设计原理到 Trae Solo Skill 实践
java·开发语言·人工智能·开源
HalvmånEver1 小时前
Linux:线程互斥
java·linux·运维
rainbow68891 小时前
深入解析C++STL:map与set底层奥秘
java·数据结构·算法
灵感菇_1 小时前
Java 锁机制全面解析
java·开发语言
indexsunny1 小时前
互联网大厂Java面试实战:Spring Boot微服务在电商场景中的应用与挑战
java·spring boot·redis·微服务·kafka·spring security·电商
娇娇乔木1 小时前
模块十一--接口/抽象方法/多态--尚硅谷Javase笔记总结
java·开发语言
saber_andlibert1 小时前
TCMalloc底层实现
java·前端·网络
wangjialelele2 小时前
平衡二叉搜索树:AVL树和红黑树
java·c语言·开发语言·数据结构·c++·算法·深度优先