首页 游戏 软件 资讯 排行榜 专题
首页
编程语言
怎么理解 HashMap 的底层哈希表实现

怎么理解 HashMap 的底层哈希表实现

热心网友
20
转载
2026-04-29

怎么理解 HashMap 的底层哈希表实现

怎么理解 HashMap 的底层哈希表实现

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

谈到HashMap,很多人知道它快,但快从何来?其底层实现,本质上是用“数组 + 链表/红黑树”这套组合拳,模拟了一张逻辑上的散列表。核心目标非常明确:把任意一个键(Key)快速、准确地映射到一个固定的内存位置,从而实现平均接近 O(1) 的存取效率。这听起来简单,背后的设计却充满了权衡与巧思。

数组是主干,“桶”决定落点

一切的基础是一个名为 Node[] table 的数组。你可以把它想象成一排排的“桶(bucket)”。数据并非按顺序存放,而是由键的哈希值来决定它的“家”在哪。举个例子,键 "user123" 经过自身的 hashCode() 方法计算,再经过HashMap内部的扰动函数处理,得到一个最终的哈希值,假设是 1987。接着,用这个值对当前数组长度取模(比如 1987 % 16 = 3),结果 3 就是它的归宿——索引为3的那个桶。这个过程,就是所谓的“哈希函数定位”,是高效访问的起点。

冲突不可避免,链表和红黑树来兜底

理想很丰满,现实却难免碰撞。不同的键完全有可能计算出相同的数组下标,这就是“哈希冲突”。比如 "abc""def" 都落到了索引5的桶里。怎么办?覆盖显然不行。于是,HashMap采用了链式结构:后来的节点就接在已有节点之后,形成一个链表。

  • 在插入方式上,JDK 7采用的是头插法,而JDK 8改为了尾插法。这一改动主要是为了解决并发扩容时可能引发的环形链表问题,提升了稳定性。
  • 那么,链表会不会太长导致查找变慢?当然会。因此,当链表长度增长到 ≥ 8 并且 此时数组的总长度也 ≥ 64 时,链表会自动升级为红黑树。这个数据结构能将查找性能从链表的 O(n) 提升到 O(log n)。
  • 反过来,如果因为删除操作导致树中的节点数减少到 ≤ 6,红黑树又会退化成链表。这避免了在数据量较小时,维护树结构带来的额外开销。

看,这里全是平衡的艺术:在空间、时间和实现复杂度之间寻找最佳实践。

键的比较必须成对重写:hashCode() + equals()

HashMap如何判断两个键是“相同”还是“不同”?这个过程是两步走的严谨校验:

  • 首先比较 hashCode():如果两个键的哈希值不同,那么它们肯定不是同一个键,可以直接放入新的位置或链表末尾。
  • 如果哈希值相等(发生了哈希碰撞),事情就没那么简单了,这时需要请出 equals() 方法进行内容的深度比较:返回 true,则视为重复键,新值会覆盖旧值;返回 false,则视为不同的键,会在链表或树中新增一个节点。

这就引出一个至关重要的实践规则:当你打算用自定义的类对象作为HashMap的键时,必须同时、一致地重写 hashCode() 和 equals() 方法。否则,即使两个对象的内容完全一致,也会因为默认的Object类方法(比较内存地址)而被判定为不同的键,导致数据重复存储,这显然不是我们想要的结果。

扩容不是小事,影响性能的关键环节

HashMap不是一成不变的,它需要成长。初始容量默认是16,加载因子默认是0.75。这意味着,当桶数组中的元素数量达到 容量 × 加载因子(即 16 * 0.75 = 12)时,扩容机制就会触发。

  • 扩容时,会创建一个容量为原来两倍的新数组(例如从16扩大到32)。
  • 接下来是一个相对耗时的操作:遍历旧数组中所有的节点,为每个节点基于新数组长度重新计算哈希和下标,然后将它们迁移到新数组对应的新“桶”中。
  • 这个过程对于链表和红黑树节点同样适用,红黑树在迁移过程中还会进行必要的平衡调整。

正因为扩容涉及大量的数据重新分配,对性能有直接影响,所以如果能在初始化时就预知大致的数据量规模,建议直接指定一个合理的初始容量(例如 new HashMap(1024)),这样可以有效减少后续扩容的次数,提升整体性能。

来源:https://www.php.cn/faq/2391331.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

松下电吹风坏了不转怎么修
电脑教程
松下电吹风坏了不转怎么修

松下电吹风插电不转?别急着扔,九成可能是这个原因 家里的松下电吹风插上电后毫无反应,风扇纹丝不动,很多人第一反应是电机烧了,维修价值不大。但事实恰恰相反,绝大多数情况下,问题并非出在核心电机上,而是前端的供电链路出现了物理性中断。根据松下官方售后技术手册以及多家授权维修中心近三年的故障统计数据,像E

热心网友
04.29
家用吸尘器的用法适合地毯清洁吗?
电脑教程
家用吸尘器的用法适合地毯清洁吗?

家用吸尘器完全适合清洁地毯,但效果高度依赖吸头设计与动力配置 先说一个核心判断:用家用吸尘器清洁地毯,这事儿完全可行,但效果好坏,关键得看装备和手法。如今,主流品牌像小熊、追觅这些,早就为地毯场景优化了产品。它们普遍配备了电动滚刷、拍打震动模块或是专用平板吸头,目的很明确——就是要松动并吸走那些死死

热心网友
04.29
按摩椅力度调小后还有效果吗
电脑教程
按摩椅力度调小后还有效果吗

按摩椅力度调小后依然有效,关键在于匹配个体身体状态与使用需求 现代中高端按摩椅普遍配备多级力度调节系统,但很多人心里犯嘀咕:力度调小了,是不是就变成隔靴搔痒,没什么实际作用了? 事实恰恰相反。实测数据显示,轻柔档位(比如30%—50%的输出强度)在缓解日常肩颈僵硬、改善浅层血液循环方面,有着明确的生

热心网友
04.29
poe交换机测试好坏能用普通测线仪吗
电脑教程
poe交换机测试好坏能用普通测线仪吗

PoE交换机好坏,普通测线仪说了不算 想用普通网线测线仪来判断一台PoE交换机的好坏?这个想法很危险。原因很简单:普通测线仪只能干些基础活儿,比如看看网线通不通、线序对不对、有没有短路断路。但对于PoE交换机的核心能力——供电电压是否达标、输出功率稳不稳定、是否兼容最新的IEEE标准、带载后电压会不

热心网友
04.29
运动耳机切换内存卡模式要配APP吗
电脑教程
运动耳机切换内存卡模式要配APP吗

运动耳机切换内存卡模式要配APP吗? 先说一个核心结论:这事儿,还真不用。绝大多数主流运动耳机,早就把切换功能“焊”在了硬件逻辑里,通过几个简单的物理按键组合就能一键搞定,全程丝滑,根本用不着打开手机APP。 你猜怎么着?比如南卡Runner Pro4,双击电源键;咏远Y12,也是双击电源键;塞那A

热心网友
04.29

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

《识质存在》中后期BD构筑攻略-中后期配装与战斗策略解析
游戏攻略
《识质存在》中后期BD构筑攻略-中后期配装与战斗策略解析

《识质存在》中后期配装与打法全解析:从生存到精通 进入《识质存在》的中后期,战场环境陡然严峻。敌人的伤害与生存压力同步攀升,单纯的武器升级已不足以应对挑战。真正的战力构建,是一个系统工程,它涵盖了武器、道具、模块天赋与侵入节点的协同搭配。如果你正为如何配装而困惑,下面的攻略或许能为你指明方向。 一、

热心网友
04.29
《黑袍纠察队》主演谈阿什莉隐藏的勇敢:“她必须管教这群‘孩子’”
游戏攻略
《黑袍纠察队》主演谈阿什莉隐藏的勇敢:“她必须管教这群‘孩子’”

《黑袍纠察队》主演揭秘阿什莉隐藏的勇敢!她如何从傀儡CEO到副总统,注射五号化合物长出第二张脸,在祖国人阴影下求生。第五季剧情解析,点击查看! 在埃里克·克里普克打造的《黑袍纠察队》宇宙里,科尔比·米尼菲饰演的阿什莉·巴雷特,绝对算得上最让人过目不忘的角色之一。尽管她在沃特国际的企业和整治阶梯上步步

热心网友
04.29
一路向西斩妖除魔 《遥遥西土》Steam好评如潮
游戏攻略
一路向西斩妖除魔 《遥遥西土》Steam好评如潮

一路向西斩妖除魔 《遥遥西土》Steam好评如潮 最近Steam上杀出了一匹黑马:由法国独立工作室Evil Raptor开发的4人合作射击游戏《遥遥西土(Far Far West)》,一登陆抢先体验就收获了玩家“好评如潮”的顶级评价。看看数据就知道有多夸张:在超过2700条玩家评价中,好评率稳稳站在

热心网友
04.29
Midnight Season 1 中最快、最简单的地牢挑战
游戏攻略
Midnight Season 1 中最快、最简单的地牢挑战

探索Midnight Season 1最快地城排名:S-Tier Collegiate Calamity等攻略,优化刷本效率,提升装备和进度 开门见山地说,在《Midnight》第一赛季里,并非所有地城(Delves)的“性价比”都一样。有的流程紧凑,一路畅通无阻;有的则弯弯绕绕,耗时费力。为了帮你

热心网友
04.29
SpringBoot2.7.x将logback升级到1.3.x以上版本的全过程解析
编程语言
SpringBoot2.7.x将logback升级到1.3.x以上版本的全过程解析

SpringBoot2 7 x将logback升级到1 3 x以上版本的全过程解析 不少开发者在尝试将SpringBoot 2 7 x项目中的Logback升级到1 3 x或更高版本时,都会遇到一个典型的启动报错。这背后的原因其实很明确:SpringBoot 2 7 x默认依赖的是logback-c

热心网友
04.29