go map

go 复制代码
// A header for a Go map.
type hmap struct {
   // Note: the format of the hmap is also encoded in cmd/compile/internal/reflectdata/reflect.go.
   // Make sure this stays in sync with the compiler's definition.
   // 元素个数,len(map)
   count     int // # live cells == size of map.  Must be first (used by len() builtin)
   // 标记是否有线程正在写
   flags     uint8
   // buckets 的对数 log_2
   B         uint8  // log_2 of # of buckets (can hold up to loadFactor * 2^B items)
   // overflow的bucket大致数量
   noverflow uint16 // approximate number of overflow buckets; see incrnoverflow for details
   //  哈希的种子,它能为哈希函数的结果引入随机性,这个值在创建哈希表时确定,并在调用哈希函数时作为参数传入
   hash0     uint32 // hash seed

   // buckets 数组,大小为 2^B
   buckets    unsafe.Pointer // array of 2^B Buckets. may be nil if count==0.
   // 旧map,不为nil时表示正在扩容
   oldbuckets unsafe.Pointer // previous bucket array of half the size, non-nil only when growing
   // 扩容进度,小于此地址的 buckets 是已经迁移完成的
   nevacuate  uintptr        // progress counter for evacuation (buckets less than this have been evacuated)

   extra *mapextra // optional fields
}

buckets 是一个指针,最终它指向的是一个结构体:

go 复制代码
// A bucket for a Go map.
type bmap struct {
   // tophash generally contains the top byte of the hash value
   // for each key in this bucket. If tophash[0] < minTopHash,
   // tophash[0] is a bucket evacuation state instead.
   tophash [bucketCnt]uint8
   // Followed by bucketCnt keys and then bucketCnt elems.
   // NOTE: packing all the keys together and then all the elems together makes the
   // code a bit more complicated than alternating key/elem/key/elem/... but it allows
   // us to eliminate padding which would be needed for, e.g., map[int64]int8.
   // Followed by an overflow pointer.
}

运行时:

go 复制代码
type bmap struct {
    topbits  [8]uint8
    keys     [8]keytype
    values   [8]valuetype
    pad      uintptr
    overflow uintptr
}

bmap 就是我们常说的"桶",桶里面会最多装 8 个 key,这些 key 之所以会落入同一个桶,是因为它们经过哈希计算后,哈希结果是"一类"的。在桶内,又会根据 key 计算出来的 hash 值的高 8 位来决定 key 到底落入桶内的哪个位置(一个桶内最多有8个位置)。

相关推荐
月亮有痕迹诶7 分钟前
【C++】智能指针
开发语言·c++·c++11
搞不懂语言的程序员13 分钟前
装饰器模式详解
开发语言·python·装饰器模式
王禄DUT17 分钟前
化学方程式配平 第33次CCF-CSP计算机软件能力认证
开发语言·c++·算法
Yang-Never19 分钟前
Open GL ES ->纹理贴图,顶点坐标和纹理坐标组合到同一个顶点缓冲对象中进行解析
android·java·开发语言·android studio·贴图
DreamByte33 分钟前
C++菜鸟教程 - 从入门到精通 第五节
开发语言·c++·算法
Ljugg1 小时前
把doi直接插入word中,然后直接生成参考文献
开发语言·c#·word
长流小哥1 小时前
可视化开发:用Qt实现Excel级动态柱状图
开发语言·c++·qt·ui
Python测试之道1 小时前
Deepseek API+Python 测试用例一键生成与导出 V1.0.6(加入分块策略,返回更完整可靠)
开发语言·python·测试用例
SRC_BLUE_171 小时前
Python GUI 编程 | QObject 控件基类详解 — 定时器
开发语言·数据库·python
啊阿狸不会拉杆1 小时前
第二十一章:Python-Plotly库实现数据动态可视化
开发语言·python·plotly