【大白话说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
相关推荐
云技纵横几秒前
线程池 OOM 实战:无界队列配错,5 万个任务撑爆 JVM
后端
假如让我当三天老蒯3 分钟前
React基础、进阶(学习用)
前端·react.js·面试
渣波11 分钟前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
笨鸟飞不快15 分钟前
从单个服务到集群:一次完整的性能排查复盘
java·前端
用户615413172812718 分钟前
# 写接口自动化时,我在断言上栽过的两个跟头
后端
荣码22 分钟前
用Streamlit给AI应用套个界面,10行代码出Web页面
java·python
SamDeepThinking26 分钟前
Java微服务练习方式
java·后端·微服务
IT_陈寒42 分钟前
Vue的响应式真把我坑惨了,原来问题出在这
前端·人工智能·后端
codedx1 小时前
LangChain 和 LangGraph 构建的 Agent 项目模版
后端·langchain·agent
葫芦和十三2 小时前
图解 MongoDB 08|ESR 原则:复合索引的字段顺序怎么定
后端·mongodb·agent