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

相关推荐
写代码写到手抽筋9 小时前
5G上行DCI字段判定:端口 流数 PMI选择详解
java·算法·5g
xieliyu.9 小时前
Java算法精讲:双指针(二)
java·开发语言·算法
jeffer_liu10 小时前
Spring AI 生产级实战:裁判员
java·人工智能·后端·spring·大模型
何以解忧,唯有..10 小时前
Python包管理工具pip:从入门到精通
开发语言·python·pip
wayz1110 小时前
Momentum:PSL(心理线指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
雪的季节10 小时前
RabbitMQ详解
开发语言
小bo波11 小时前
枚举实战
java·设计模式·枚举·后端开发·代码重构
8Qi811 小时前
LeetCode 213:打家劫舍 II(House Robber II)—— 题解 ✅
算法·leetcode·职场和发展·动态规划
ice81303318111 小时前
【Python】Matplotlib折线图绘制
开发语言·python·matplotlib