百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

HashMap数据结构最全详解(图文全面总结)

liuian 2025-05-27 15:53 30 浏览

HashMap是大厂面试经常考察的内容,重点就会涉及到:数据结构与底层原理等,下面我就全面来详解@mikechen

本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。

HashMap

HashMap是Java集合框架非常常用的一个类,主要用于实现哈希映射。

在Java中HashMap是基于AbstractMap类实现的,并且实现了Map接口。

如下图所示:

HashMap继承了AbstractMap类,并且同时实现了Map接口,使得它能够以键值对的形式存储和操作数据。

HashMap数据结构

从结构实现来讲,HashMap是(数组+链表+红黑树)来实现的,JDK1.8增加了红黑树部分的实现。

如下图所示:

1.数组(Array)

HashMap使用一个数组作为底层的数据存储结构,称为“桶数组”(bucket array)。

数组的每个位置被称为一个“”(就是上图的蓝色部分),每个桶可以存储一个或多个键值对。

上图中的每个蓝色色圆点就是一个“桶”,也就是一个Node对象。

如下所示:

static class Node<K, V> implements Map.Entry<K, V> {
    final int hash;
    final K key;
    V value;
    Node<K, V> next;  // 下一个节点的引用

    // 构造函数等代码
    // ...

    // JDK 1.8中新增的红黑树相关字段
    TreeNode<K, V> parent;
    TreeNode<K, V> left;
    TreeNode<K, V> right;
    TreeNode<K, V> prev;
    boolean red;
}

Node节点是HashMap中用于存储键值对的基本单元,它包含:键、值、哈希值、下一个节点的引用等信息。

在JDK 1.8中,为了提高查找性能,当链表中的节点数量超过一定阈值时,链表会被转换为红黑树。

因此,Node在JDK 1.8中有两种形式:普通节点和红黑树节点。

2.链表(Linked List)

在哈希表中,不同的键可能会映射到相同的数组索引位置,从而引发哈希冲突。

为了解决哈希冲突的一种常见方法是链式法(Chaining),也就是链表。

如下图所示:

当哈希冲突发生时,具有相同哈希值的键值对会被存储在同一个桶中,形成一个链表。

下面是哈希冲突的链表过程:

1.哈希函数映射

当插入一个键值对时,首先通过哈希函数计算键的哈希值,然后将该哈希值映射到数组索引。

2.存储键值对

如果计算得到的数组索引上没有存储键值对,则直接将键值对存储在该位置上。

如果已经存在一个键值对,则发生哈希冲突。

3.链表存储

当哈希冲突发生时,采用链式法,在同一个哈希桶中,会创建一个链表,将具有相同哈希值的键值对链接在一起。

4.查找键值对

当查找一个键对应的值时,首先计算键的哈希值,然后根据哈希值找到数组索引。

在该索引位置的链表中搜索目标键,如果找到则返回对应的值。

3.红黑树(Red-Black Tree)

在JDK 1.8中,为了解决链表过长导致性能问题,当链表中的元素数量超过一定阈值(默认为8)时,会将链表转换为红黑树。

如下图所示:

红黑树具有更好的查找性能,因此能够在链表效率变差时提供更好的性能。

红黑树具有以下特性:

  • 节点颜色: 每个节点要么是红色,要么是黑色。
  • 根节点和叶子节点(NIL节点): 根节点是黑色的,而叶子节点(NIL节点,通常是空节点)是黑色的。
  • 红色节点规则: 红色节点的子节点必须是黑色的,这意味着在从根到叶子的任意路径上不能有两个连续的红色节点。
  • 黑色高度平衡: 从任意节点出发,到达其叶子节点的所有路径中,黑色节点的数量必须相同。

当链表转换为红黑树时,HashMap将现有的链表节点按照键的比较顺序重新构建一棵红黑树。

这样,HashMap在平均情况下能够实现更快的查找操作,因为红黑树的查找时间复杂度为O(log n),相比链表的O(n)要好。

总结而言,红黑树是一种用于自平衡的二叉搜索树,在HashMap中用于优化链表的性能。

4.哈希函数

HashMap的哈希函数(Hash Function)是用于将键(Key)映射到数组索引的算法。

HashMap中的哈希函数由以下步骤组成:

1)计算哈希码值(Hash Code)

对键调用其hashCode()方法,获得一个32位的整数哈希码值。

哈希码值在理想情况下应该是一个分布均匀、随机分布的整数。

2)哈希码值的处理

获得的哈希码值可能不在HashMap的数组索引范围内(即数组长度),因此需要将哈希码值映射到数组索引范围。

这通常通过对哈希码值取模操作来实现,即hashcode % 数组长度。

3)解决哈希冲突

如果不同的键获得了相同的哈希码值,即哈希冲突,HashMap使用链式法来解决冲突。

即当多个键映射到同一个索引时,它们被存储在同一个桶中,通过链表(或红黑树)链接在一起。

5.负载因子和扩容

HashMap还有一个负载因子(load factor)的概念,表示已存储的键值对数量与桶数组大小的比率。

当负载因子超过一定阈值时,HashMap会进行扩容操作。

扩容时,会创建一个更大的桶数组,将现有的键值对重新分配到新的桶中,以减少冲突,保持高效性能。

hashmap数据结构总结

综上所述,HashMap的数据结构基于哈希表,通过哈希函数将键映射到数组索引,使用链式法或红黑树来解决冲突,并通过负载因子和扩容来维持高效性能。

本篇已收于mikechen原创超30万字《阿里架构师进阶专题合集》里面。

相关推荐

搭建一个20人的办公网络(适用于20多人的小型办公网络环境)

楼主有5台机上网,则需要一个8口路由器,组网方法如下:设备:1、8口路由器一台,其中8口为LAN(局域网)端口,一个WAN(广域网)端口,价格100--400元2、网线N米,这个你自己会看了:)...

笔记本电脑各种参数介绍(笔记本电脑各项参数新手普及知识)

1、CPU:这个主要取决于频率和二级缓存,频率越高、二级缓存越大,速度越快,现在的CPU有三级缓存、四级缓存等,都影响相应速度。2、内存:内存的存取速度取决于接口、颗粒数量多少与储存大小,一般来说,内...

汉字上面带拼音输入法下载(字上面带拼音的输入法是哪个)

使用手机上的拼音输入法打成汉字的方法如下:1.打开手机上的拼音输入法,在输入框中输入汉字的拼音,例如“nihao”。2.根据输入法提示的候选词,选择正确的汉字。例如,如果输入“nihao”,输...

xpsp3安装版系统下载(windowsxpsp3安装教程)

xpsp3纯净版在采用微软封装部署技术的基础上,结合作者的实际工作经验,融合了许多实用的功能。它通过一键分区、一键装系统、自动装驱动、一键设定分辨率,一键填IP,一键Ghost备份(恢复)等一系列...

没有备份的手机数据怎么恢复

手机没有备份恢复数据方法如下1、使用数据线将手机与电脑连接好,在“我的电脑”中可以看到手机的盘符。  2、将手机开启USB调试模式。在手机设置中找到开发者选项,然后点击“开启USB调试模式”。  3、...

电脑怎么激活windows11专业版

win11专业版激活方法有多种,以下提供两种常用的激活方式:方法一:使用激活密钥激活。在win11桌面上右键点击“此电脑”,选择“属性”选项。进入属性页面后,点击“更改产品密钥或升级windows”。...

华为手机助手下载官网(华为手机助手app下载专区)

华为手机助手策略调整,已不支持从应用市场下载手机助手,目前华为手机助手是需要在电脑上下载或更新手机助手到最新版本,https://consumer.huawei.com/cn/support/his...

光纤线断了怎么接(宽带光纤线断了怎么接)

宽带光纤线断了可以重接,具体操作方法如下:1、光纤连接的时候要根据束管内,同色相连,同芯相连,按顺序进行连接,由大到小。一般有三种连接方法,分别是熔接、活动连接和机械连接。2、连接的时候要开剥光缆,抛...

深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
  • 深度操作系统安装教程(深度操作系统安装教程图解)
win7旗舰版和专业版区别(win7旗舰版跟专业版)

1、功能区别:Win7旗舰版比专业版多了三个功能,分别是Bitlocker、BitlockerToGo和多语言界面; 2、用途区别:旗舰版的功能是所有版本中最全最强大的,占用的系统资源,...

万能连接钥匙(万能wifi连接钥匙下载)

1、首先打开wifi万能钥匙软件,若手机没有开启WLAN,就根据软件提示打开WLAN开关;2、打开WLAN开关后,会显示附近的WiFi,如果知道密码,可点击相应WiFi后点击‘输入密码’连接;3、若不...

雨林木风音乐叫什么(雨林木风是啥)

雨林木风的创始人是陈年鑫先生。陈年鑫先生于1999年创立了雨林木风公司,其初衷是为满足中国市场对高品质、高性能电脑的需求。在陈年鑫先生的领导下,雨林木风以技术创新、产品质量和客户服务为核心价值,不断推...

aics6序列号永久序列号(aics6破解序列号)

关于AICS6这个版本,虽然是比较久远的版本,但是在功能上也是十分全面和强大的,作为一名平面设计师的话,AICS6的现有的功能已经能够应付几乎所有的设计工作了……到底AICC2019的功能是不是...

win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
  • win7正在启动windows 卡住(win7正在启动windows卡住了 进入安全模式)
手机可以装电脑系统吗(手机可以装电脑系统吗怎么装)

答题公式1:手机可以通过数据线或无线连接的方式给电脑装系统。手机安装系统需要一定的技巧和软件支持,一般需要通过数据线或无线连接的方式与电脑连接,并下载相应的软件和系统文件进行安装。对于大部分手机用户来...