【大白话说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基础篇

相关推荐
自由路飞3 小时前
RAG 混合检索深挖:BM25 和向量分数为什么不能直接相加?
面试
Yeats_Liao3 小时前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿3 小时前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试
鹤望兰6753 小时前
字节跳动国际支付-后端开发-三面面经
java
Flittly3 小时前
【AgentScope Java新手村系列】(14)人机交互
java·spring boot·spring
RainCity3 小时前
Java Swing 自定义组件库分享(十二)
java·笔记·后端
阳光是sunny14 小时前
Vue 项目怎么做用户行为全链路监控?轻量插件方案详解
前端·面试·架构
蝎子莱莱爱打怪15 小时前
DSpark 讲透:DeepSeek 不换模型,硬把 V4 提速 85%,是怎么做到的?
人工智能·面试·程序员
吃饱了得干活19 小时前
Spring Cloud Gateway 微服务网关:路由、断言、过滤器
java·spring cloud
lwx5728021 小时前
探秘InnoDB:搞懂它的内存、线程、磁盘与日志刷盘策略
java·后端