【大白话说Java面试题】【Java基础篇】第17题:HashMap的加载因子为什么是0.75而不是1或0.5

第17题:HashMap的加载因子为什么是0.75而不是1或0.5

📚 回答:

  • 背景知识
    HashMap的加载因子(loadFactor)决定了数组在扩容前可以存储多少元素。默认值为0.75,这是在空间占用和查询性能之间的一个权衡值。

  • 为什么不是1?

    • 如果加载因子设为1,意味着数组会在完全装满时才触发扩容。
    • 这样虽然节省了空间,但会导致哈希冲突的概率显著增加,链表长度变长,查询效率降低(时间复杂度从O(1)退化为O(n))。
  • 为什么不是0.5?

    • 如果加载因子设为0.5,意味着数组在只装了一半时就会触发扩容。
    • 虽然减少了哈希冲突的概率,但会导致频繁扩容,占用更多的内存空间,影响性能。
  • 为什么是0.75?

    • 加载因子为0.75是一个经验值,在空间利用率和查询性能之间找到了平衡点:

      • 空间利用率高:数组不会过早扩容,避免浪费内存。
      • 查询性能优:哈希冲突的概率较低,链表长度较短,查询效率较高。

      💡 面试官视角

  • 面试官可能会问"有没有场景需要调整加载因子?"答:在内存敏感的场景下可以适当增大加载因子(如0.8),而在性能敏感的场景下可以适当减小加载因子(如0.6)。

  • 面试官可能会追问"加载因子对扩容有什么影响?"答:加载因子越小,扩容越频繁;加载因子越大,扩容越少,但冲突概率增加。


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

相关推荐
huipeng9262 小时前
GateWay使用详解
java·spring boot·spring cloud·微服务·gateway
谭欣辰2 小时前
C++ 哈希表详解
c++·算法·哈希算法·散列表
AKA__Zas2 小时前
初识多线程(初初识)
java·服务器·开发语言·学习方法
zhangrelay2 小时前
三分钟云课实践速通--概率统计--python版
linux·开发语言·笔记·python·学习·ubuntu
shehuiyuelaiyuehao2 小时前
算法11,滑动窗口,最大连续1的个数|||
算法·leetcode·职场和发展
南宫萧幕2 小时前
车辆能量管理进阶:从前沿算法 (VMD-PPO-DBO) 机制解析到 MPC 工程建模
人工智能·算法·matlab·simulink·控制
张赐荣2 小时前
深入详解在 Python 中用 ctypes 调用 Windows API 清空回收站
开发语言·windows·python
费曼学习法2 小时前
快速选择算法:如何在 10 亿数据中瞬间找到“第 K 大”?
javascript·算法
彷徨而立2 小时前
【C/C++】在头文件中定义全局变量的方法
c语言·开发语言·c++