【大白话说Java面试题】【Java基础篇】01_说说ArrayList的底层原理/扩容规则

第1题:说说ArrayList的底层原理/扩容规则

📚 回答:

  • 底层实现
    ArrayList基于动态数组实现,初始底层数组长度取决于构造方式:

    • 空参构造:初始长度为0(即elementData为空数组)。
    • 有参构造:直接初始化为指定容量的数组(如new ArrayList<>(20))。
  • 扩容规则

    1. 使用add方法时的扩容规则
    • 空参构造
      • 首次调用add方法时,扩容到默认容量10。
      • 后续扩容:新容量为上一次容量的1.5倍,计算公式为新容量 = 原容量 + (原容量 >> 1)
    • 有参构造
      • 直接初始化为指定容量(如20)。只有当添加的元素数量超过初始容量时,才会触发扩容。
      • 扩容规则与空参构造一致:新容量为上一次容量的1.5倍。
    2. 使用addAll方法时的扩容规则
    • 如果集合原本为空:

      扩容后容量取Math.max(10, 实际元素个数)

    • 如果集合原本有元素:

      扩容后容量取Math.max(原容量1.5倍, 实际元素个数)

💡 面试官视角:

  • 面试官可能会追问"为什么扩容是1.5倍?"答:1.5倍是一个折中值,既能减少频繁扩容的开销,又不会浪费过多内存空间。
  • 面试官可能会问"扩容过程中是如何保证线程安全的?"答:ArrayList本身不是线程安全的,扩容时可能会出现并发问题,比如多个线程同时扩容导致数据不一致。如果需要线程安全,可以使用Collections.synchronizedListCopyOnWriteArrayList
相关推荐
赏金术士6 分钟前
Kotlin 习题集 · 进阶篇
java·数据库·kotlin
Java水解8 分钟前
如何更好的创建skill
后端
Kang.lee9 分钟前
2026.5.12【芯片设计面试经验分享】上海车载芯片设计公司
经验分享·面试·职场和发展
ch.ju10 分钟前
Java程序设计(第3版)第三章——数组的遍历
java·开发语言
何故染尘優11 分钟前
面试八股文-01
java·jvm·面试
青春易逝丶15 分钟前
JAVA基础面试题
java·开发语言
Gopher_HBo18 分钟前
阻塞队列之PriorityBlockingQueue
后端
Austindatabases18 分钟前
数据不准确,数据丢失,SQLite怎么保证计算不丢数--SQLite 五脏俱全系列 (5)
java·开发语言·数据库·sqlite
滑稽之神眷顾者19 分钟前
基于正倒排索引的文档搜索引擎测试报告
java·开发语言·功能测试
霸道流氓气质20 分钟前
Spring AI ChatMemory 对话记忆配置指南:概念、实战与常见问题
java·人工智能·spring