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

相关推荐
AbandonForce1 小时前
Map类:pair键值对|map的基本操作|operator[]
开发语言·c++·算法·leetcode
澈2071 小时前
C++核心:封装与static静态成员实战指南
开发语言·c++·算法
想躺平的小羊1 小时前
IDEA 如何显示或关闭项目类的结构(类的方法)
java·ide·intellij-idea
A-Jie-Y1 小时前
JAVA设计模式-建造者模式
java·设计模式
ShineWinsu1 小时前
对于Linux:进程间通信IPC(匿名管道)的解析
linux·c++·面试·进程·通信·管道·ipc
wuyoula1 小时前
全新多平台电商代付商城源码
开发语言·c++·ui·小程序·php源码
玖疯子1 小时前
IT疑难杂症诊疗室:系统性故障排查指南
开发语言·php
曹牧1 小时前
Java Web 开发:servlet-mapping‌
java·数据仓库·hive·hadoop
码云数智-大飞1 小时前
OpCache 原理深挖:从字节码缓存到预加载(Preloading)的实战配置
java·开发语言