【大白话说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
相关推荐
卷无止境3 分钟前
零信任架构与传统边界安全:一场关于"信任"的根本分歧
后端
风止何安啊4 分钟前
我一个前端仔,居然用 Python 搞起了 AI?从零到一,撸了个 AI 聊天框小 demo
前端·人工智能·后端
我是唐青枫9 分钟前
Java JdbcTemplate 实战指南:用 Spring 轻量完成数据库增删改查
java·数据库·spring
逍遥运德16 分钟前
PostgreSQL ---【序列】用法详解
后端·sql·postgresql
Lumbrologist31 分钟前
【C++】零基础入门 · 第 13 节:类与对象基础
java·c++·算法
码不停蹄的玄黓37 分钟前
Java 生产者-消费者模型详解
java·开发语言·python
笨蛋不要掉眼泪44 分钟前
Java并发编程:Executors框架类深度解析
java·开发语言·并发
南极企鹅1 小时前
深入理解 MVCC:数据库并发控制的基石
java·数据库·mysql
回家路上绕了弯1 小时前
AgentScope Harness 深度实战:让Java智能体从“Demo可用”走向“生产可用”
后端
卷心菜投手ovo1 小时前
RAG 为什么引用总是对不上?
后端·github