Golang中map数据结构字段解析

Golang里map底层数据结构具体如下图所示:
在这里插入图片描述
map其实就是一个指向 hmap 的指针,占用了8个字节

hmap各自段存放的字段意义如下:

字段含义
countmap中元素的个数,对应len (map)的值
flags状态标志位,标记map的一些状态
B桶数以2为底的对数,即B=log_2(len(buckets)),比如B=3,那么桶数为2^3=8
noverflow溢出桶数量近似值
hash0哈希种子
*buckets指向buckets数组的指针,buckets数组的元素为bmap,如果数组元素个数为0,其值nil
*oldbuckets是一个指向buckets数组的指针,在扩容时,oldbuckets 指向老的buckets数组(大小为oldbuckets为空
nevacuate表示扩容进度的一个计数器,小于该值的桶已经完成迁移
extra指向mapextra结构的指针,mapextra存储map中的溢出桶

bmap数组内各自段存放的字段意义如下:

字段含义
tophash代表哈希桶中该元素的高字节,在哈希冲突发生时,快速对比两个键的高字节判断是否相等,避免每次都需要比较完整的键,提高了比较的效率
keys存储了bmap里8个key/value键值对的key
values存储了bmap里8个key/value键值对的value
*overflow指向溢出桶的指针

hmap其中最重要的就是buckets,它指向了一个包含多个结构为bmap(桶)的bucket数组,bucket的底层采用链表将bmap链接起来。
[]bmap是一个底层数组,我们把它称之为 桶(哈希桶)数组 ,它被*buckets所指向,是真正用于存储数据的地方。

在这里插入图片描述

每一个bmap能存储8个键值对,当map中的数据过多,bmap数组存不下的适合就会存储到extra指向的溢出的bucket(桶)里面
在这里插入图片描述

字段含义
overflow溢出桶链表地址
nextOverflow下一个空闲溢出地址

因为哈希冲突的原因,所以一般[]bmap数组只存放一个指针,该指针指向一个链表用于存放键值对

哈希冲突是什么意思?

存储一个key / value 键值对时,存放到正确的位置需要进行两个步骤
1.通过哈希函数hashFunc计算hash值
2.计算索引位置 (hash值对桶取模得到索引值)

但是如果有两个键值对通过计算得到的哈希值相同,这两个键值对的索引也必然相同,那么也会存放到同一个位置,那该怎么处理?覆盖某一个键值对?舍弃某一个键值对? 这就是哈希碰撞的问题,当然,对于这两组键值对最后的处理结果,必然是都存储下来的。

解决哈希碰撞一般都有两种方式:拉链法开放寻址法

拉链法:
在buckets中不存储数据元素,而是存放指针,该指针指向一个链表,当出现key1和key2哈希值相同的情况,那就将数据链接到链表上,如果没有出现哈希碰撞的情况,buckets数组中某个索引位置存放的指针,指向的链表中自然只有一个元素了。
当链表元素过长,则推荐使用红黑树代替链表
在这里插入图片描述

开放寻址法
开放地址法是另外一种非常常用的解决哈希冲突的策略,与拉链法不同,开放地址法是将具体的数据元素存储在数组桶中,在要插入新元素时,先根据哈希函数算出hash值,根据hash值计算索引,如果发现冲突了,计算出的数组索引位置已经有数据了,就继续向后探测,直到找到未使用的数据槽为止。
在这里插入图片描述
在存储键值对<b,101>的时候,经过hash计算,发现原本应该存放在数组下标为2的位置已经有值了,存放了<a,100>,就继续向后探测,发现数组下标为3的位置是空槽,未被使用,就将<b,101>存放在这个位置。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/542105.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【C++语言】冲突-C语言:命名空间

文章目录 前言1.命名空间&#xff1a;namespace关键字1.命名空间中可以定义变量、函数、类型2.命名空间可以嵌套3.相同命名空间共存 2 命名空间的使用方式&#xff1a;1.名称加用域作用限定符的方式访问&#xff08;同上&#xff09;2.使用using引入某个空间中的某个变量3.使用…

数据链路层_以太网

IP协议确定数据跨网络从主机A到主机B的路径&#xff0c;即IP协议解决了路径选择问题&#xff0c;但在这之前&#xff0c;必须先解决数据在一个子网内的传输的问题。跨网络的本质就是跨多个子网&#xff0c;只要一个子网内可以通信&#xff0c;那么便可以跨网络通信。 一.以太…

【算法杂货铺】二分算法

目录 &#x1f308;前言&#x1f308; &#x1f4c1; 朴素二分查找 &#x1f4c2; 朴素二分模板 &#x1f4c1; 查找区间端点处 细节&#xff08;重要&#xff09; &#x1f4c2; 区间左端点处模板 &#x1f4c2; 区间右端点处模板 &#x1f4c1; 习题 1. 35. 搜索插入位…

Spring Cloud Gateway针对指定接口做响应超时时间限制

背景&#xff1a;我做的这个服务中存在要对大数据量做自定义统计的接口和大文件上传接口&#xff0c;接口响应用时会超过gateWay配置的全局用时&#xff0c;如果调整网关全局的超时时间和服务的全局超时时间是不合理的&#xff0c;故此想能否单独针对某个接口进行细粒度超时限制…

CXL-Enabled Enhanced Memory Functions——论文阅读

IEEE Micro 2023 Paper CXL论文阅读笔记整理 问题 计算快速链路&#xff08;CXL&#xff09;协议是系统社区的一个重要里程碑。CXL提供了标准化的缓存一致性内存协议&#xff0c;可用于将设备和内存连接到系统&#xff0c;同时保持与主机处理器的内存一致性。CXL使加速器&…

【Hadoop】Hadoop概述与核心组件

目录 Hadoop概述Hadoop 发展历史Hadoop 三大发行版本1.Apache Hadoop&#xff08;常用&#xff09;2.Cloudera Hadoop3.Hortonworks Hadoop优势优势总结——4高&#xff08;高可靠、高扩展、高效、高容错&#xff09; Hadoop组成1.HDFS管理者&#xff1a;NameNode&#xff08;n…

鸿蒙Harmony应用开发—ArkTS声明式开发(容器组件:GridItem)

网格容器中单项内容容器。 说明&#xff1a; 该组件从API Version 7开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。仅支持作为Grid组件的子组件使用。 子组件 可以包含单个子组件。 接口 GridItem GridItem(value?: GridItemOptions)…

分布式系统常见负载均衡实现模式

分布式系统常见负载均衡实现模式 1. 4层负载均衡1.1. 负载均衡的常见需求1.2. 负载均衡的实现模式1.2.1 DR模式1.2.2 TUN模式1.2.3 NAT模式1.2.4 FULLNAT模式1.2.5 4种模式的差异 1.3. 负载均衡的均衡算法1.3.1 静态负载均衡1.3.2 轮询法1.3.3 加权循环法1.3.4 IP 哈希法1.3.5 …

FPGA高端项目:FPGA基于GS2971+GS2972架构的SDI视频收发+OSD动态字符叠加,提供1套工程源码和技术支持

目录 1、前言免责声明 2、相关方案推荐本博已有的 SDI 编解码方案本方案的SDI接收发送本方案的SDI接收图像缩放应用本方案的SDI接收纯verilog图像缩放纯verilog多路视频拼接应用本方案的SDI接收HLS图像缩放HLS多路视频拼接应用本方案的SDI接收HLS多路视频融合叠加应用本方案的S…

C++提高笔记(四)---STL容器(stack、queue、list)

1、stack容器&#xff08;栈&#xff09; 1.1 栈stack基本概念 概念&#xff1a;stack是一种先进后出&#xff08;First In Last Out&#xff0c;FILO&#xff09;的数据结构&#xff0c;它只有一个出口 栈中只有顶端的元素才可以被外界调用&#xff0c;因此栈不允许有遍历行…

Linux——动静态库的制作及使用与动态库原理

目录 一、静态库 1.静态库的制作 2.静态库的使用 加载静态库方法一&#xff1a;安装头文件与库文件 加载静态库方法二&#xff1a;指定文件目录 二、动态库 1.动态库的制作 2.动态库的使用 方法一&#xff1a;安装到系统中 方法二&#xff1a;软链接 方法三&…

Light Random Sprays Retinex 传统的图像增强算法LRSR

文章目录 前言1、Light Random Sprays Retinex 概况2、Light Random Sprays Retinex 具体实现2.1、噪声去除2.2、亮度调整2.3、插值技术 3、Light Random Sprays Retinex源码4、Light Random Sprays Retinex效果及结论 前言 Light Random Sprays Retinex, 即“光随机喷雾Retine…