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)

两者尾插法 都一样的效率

相同

  • 不同步

  • 线程不安全

  • 但是效率高

相关推荐
咸鱼2.01 小时前
【java入门到放弃】Dubbo
java·开发语言·dubbo
JAVA面经实录9177 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
许彰午9 小时前
CacheSQL(二):主从复制——OpLog 环形缓冲区与故障自动恢复
java·数据库·缓存
Bat U10 小时前
JavaEE|多线程初阶(七)
java·开发语言
掌心向暖RPA自动化12 小时前
如何获取网页某个元素在屏幕可见部分的中心坐标影刀RPA懒加载坐标定位技巧
java·javascript·自动化·rpa·影刀rpa
日取其半万世不竭13 小时前
Minecraft Java版社区服务器搭建教程(Linux,适合新手)
java·linux·服务器
TeamDev13 小时前
JxBrowser 9.0.0 版本发布啦!
java·前端·混合应用·jxbrowser·浏览器控件·跨平台渲染·原声输入
AI人工智能+电脑小能手14 小时前
【大白话说Java面试题】【Java基础篇】第24题:Java面向对象有哪些特征
java·开发语言·后端·面试
AI人工智能+电脑小能手14 小时前
【大白话说Java面试题】【Java基础篇】第25题:JDK1.8的新特性有哪些
java·开发语言·后端·面试
likerhood14 小时前
SLF4J: Failed to load class “StaticLoggerBinder“ 解决
java·log4j·maven