【大白话说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
相关推荐
高斯林.神犇2 小时前
六、java配置类改造ioc
java·开发语言
zuowei28892 小时前
Spring BOOT 启动参数
java·spring boot·后端
星浩AI2 小时前
手把手带你在 Windows 安装 Hermess Agent,并接入飞书 [喂饭级教程含踩坑经验]
人工智能·后端·agent
神奇小汤圆2 小时前
Spring Boot 入门:Java 生态最流行的应用开发框架介绍
后端
龙月2 小时前
Gitlab迁移与升级技术方案
前端·后端
张小洛2 小时前
Spring 常用类深度剖析(工具篇 04):CollectionUtils 与 Stream API 的对比与融合
java·后端·spring·spring工具类·spring utils·spring 类解析
Ruihong3 小时前
你的 Vue KeepAlive 组件,VuReact 会编译成什么样的 React 代码?
vue.js·react.js·面试
kunge20133 小时前
UBUNTU Claude Code 报错 claude native binary not installed
后端
Ruihong3 小时前
你的 Vue slot 插槽,VuReact 会编译成什么样的 React 代码?
vue.js·react.js·面试