java 集合中arrayList为什么查询比较快,而插入和删除比较慢

  1. 底层数据结构
    ArrayList 基于动态数组实现,内部通过一个连续的数组存储元素。数组的内存空间是连续分配的,并且每个元素都有固定的索引位置。

  2. 查询快的原因

    由于数组是连续存储的,ArrayList 可以通过索引直接访问元素 (时间复杂度为 O (1))。 计算机通过数组的首地址寻址公式能够很快的找到想要访问的元素

java 复制代码
寻址公式 = 基地址 + 索引 × 元素大小

例如,要获取第 i 个元素,只需通过公式 elementData[i] 直接计算内存地址并访问,无需遍历前面的元素。

  1. 插入和删除慢的原因

  2. 数组是臆断连续的内存空间,因此为了保证数组的连续性会使得数组的插入和删除的效率变得很低

  3. 当在数组中间或头部进行插入 / 删除操作时:

    • 需要移动受影响的元素 来维持数组的连续性。
      例如,在索引 i 处插入元素时,需要将 i 及之后的所有元素向后移动一位;删除时则需要将 i 之后的所有元素向前移动一位。
    • 移动元素的操作时间复杂度为 O (n)(n 为元素总数),元素越多,效率越低。
    • 此外,当数组容量不足时,ArrayList 会触发扩容机制(通常是创建原容量 1.5 倍的新数组,并复制所有元素),这也会额外消耗时间。
相关推荐
Penge6662 小时前
Go 接口编译期断言
后端
我是一颗柠檬2 小时前
【MySQL全面教学】MySQL面试高频考点汇总Day15(2026年)
数据库·后端·mysql·面试
橙淮3 小时前
并发编程(六)
java·jvm
拽着尾巴的鱼儿3 小时前
springboot openfeign 自定义feign 接口重试机制
java·spring boot·后端
白露与泡影3 小时前
2026大厂Java面试题大全!牛客网最新版
java·开发语言
Ceelog3 小时前
久坐党自救指南:屏幕前 8 小时,身体到底在经历什么
前端·后端
EntyIU4 小时前
JVM内存与GC笔记
java·jvm·笔记
swipe4 小时前
DeepAgents 实战:用多 Agent 架构搭一个深度调研助手
javascript·面试·llm
XS0301064 小时前
并发编程 六
java·后端
yaoxin5211234 小时前
419. 现代 Java IO 最佳实践 - 写入文本文件
java·windows·python