【大白话说Java面试题】【Java基础篇】第18题:HashMap底层是如何扩容的

第18题:HashMap底层是如何扩容的

📚 回答:

  • 扩容条件

    • HashMap的初始容量为16,默认负载因子为0.75。
    • 当元素个数超过capacity * loadFactor(即16 * 0.75 = 12)时,会触发扩容。
  • 扩容过程

    1. 容量翻倍
      • 数组长度变为原来的2倍(如从16扩展到32)。
      • 扩容后的新数组长度始终是2的幂,确保散列分布均匀。
    2. 重新计算索引
      • 每个元素都需要重新计算其存储位置(index)。
      • 新索引通过(length - 1) & hash计算得出。
    3. 数据迁移
      • 将旧数组中的元素迁移到新数组中。
      • 在JDK1.7中,采用头插法进行迁移,可能导致死循环问题(见第15题)。
      • 在JDK1.8中,改用尾插法,避免了死循环问题。
    4. 红黑树处理
      • 如果桶内是红黑树节点,可能需要重新拆分为链表或保持红黑树结构,具体取决于迁移后的节点数量。
  • 限制条件

    • 数组的最大长度为Integer.MAX_VALUE(即2^31 - 1)。
    • 扩容后的负载因子最大只能达到2^30

    💡 面试官视角

  • 面试官可能会问"为什么扩容是2倍?"答:扩容为2倍可以保证数组长度始终是2的幂,从而利用位运算高效计算索引。

  • 面试官可能会追问"扩容时为什么要重新计算索引?"答:因为扩容后数组长度变化,(length - 1) & hash的结果也会变化,因此需要重新计算每个元素的位置。


📌 专栏 :大白话说Java面试题 --- 01-Java基础篇

相关推荐
ANnianStriver2 分钟前
PetLumina 05 — App 端 UI 效果应用
java·ui·ai编程
不懂的浪漫4 分钟前
10|Netty native epoll 与零拷贝:从 Java NIO 再往下看一层![
java·netty·nio
许彰午4 分钟前
24_Java NIO核心组件
java·python·nio
不会C语言的男孩5 分钟前
C++ Primer 第18章:用于大型程序的工具
开发语言·c++
摇滚侠8 分钟前
Spring 零基础入门到进阶 入门 06-10
java·spring·intellij-idea
要开心吖ZSH11 分钟前
AI医疗分诊与健康咨询助手agent开发——(1)从零搭建SpringBoot与AI对话系统:后端骨架 + 前端对话页 + SSE流式输出
java·ai·agent·健康医疗
星恒随风11 分钟前
C++ 类和对象入门(三):拷贝构造、赋值运算符重载和深浅拷贝
开发语言·c++·笔记·学习
RickyWasYoung13 分钟前
【Matlab】科研绘图配色-极简版
开发语言·matlab
biubiubiu070613 分钟前
SpringBoot生产级日志配置
java·spring boot·后端
凡人叶枫14 分钟前
Effective C++ 条款03:尽可能使用 const
linux·开发语言·c++·嵌入式开发