搜尋
首頁後端開發Golanggolang map的實作講解
golang map的實作講解Mar 29, 2023 am 09:24 AM
golang

Golang是一門新興的程式語言,它的map是基於哈希表實現的。在這篇文章中,我們將討論Golang中map的實作方式。具體來說,我們將介紹哈希表的概念、Golang map的結構和效能最佳化。

哈希表的概念

哈希表是一種以鍵值對儲存資料的資料結構。它透過雜湊函數將鍵映射到陣列索引,使得對操作雜湊表內資料的存取變得更加有效率。

雜湊函數將傳遞給它的值計算為一個較小的固定長度值,這個值唯一地標識了這個鍵(這種稱為雜湊碼)。這個哈希碼被使用作為數組索引。

雜湊函數存在一些問題。一是哈希碰撞,即不同的鍵映射到相同的數組索引,需要採用解決哈希碰撞的方式來解決。另一種問題是雜湊函數的不足,它可能無法準確地計算值的雜湊碼,導致雜湊表中的資料分佈不均。

Golang map的結構

在Golang中,map是一種結構,它的底層資料結構是哈希表。具體來說,map由以下三個欄位組成:

type hmap struct {
    count int                                 
    flags uint32                              
    B     uint8                               
    hash0 uint32                              
    buckets unsafe.Pointer // 指向一个桶数组
    oldbuckets unsafe.Pointer // 用于扩容时的桶数组
    nevacuate uintptr // 当前将要被载入到oldbuckets的指针位置
    extra *mapextra
}

其中,count表示map中的元素數量;flags用於記錄map的狀態,包括是否刪除、是否迭代中等;B表示桶數組的長度,即2的B次方;hash0記錄的是哈希種子,用於雜湊函數的計算。

buckets是一個指針,它指向一個桶數組。桶數組的格式如下:

type bmap struct {
    tophash [bucketCnt]uint8
    data    [1]struct{ key, value interface{} }
}

其中,tophash是一個長度為bucketCnt的數組,每個元素表示bmap中的一個元素,它的值是一個整數,用於定位data中的鍵值對。 data是一個長度為1的數組,其中包含一個鍵值對。鍵值對的格式如下:

type iface struct {
    tab  *itab
    data unsafe.Pointer
}

type itab struct {
    inter  *interfacetype
    _type  *_type
    link   *itab
    bad    int32
    inhash int32 // 是否在哈希表中
    funcbucket uintptr
    __hash uintptr // 哈希函数(方法)
    __eq   uintptr // 判断是否相等的函数(方法)
}

其中,data欄位是一個指向iface結構體的指針,iface結構體包含一個指向儲存鍵值對的指標和一個指向型別資訊的指標。

Golang map的效能最佳化

Golang map實作的效能最佳化主要分為以下兩個面向:

  1. 桶數組擴容

當map中的元素數量超過桶數組的容量時,桶數組需要進行擴容。擴容的方式是增加一個新的桶數組。在下一次訪問map的時候,所有的鍵值對會被重新計算,然後被逐個移動到新的桶數組中。這個過程叫做rehash。

桶數組擴容過程中,Golang使用了一個叫做randomized-hashing的技術。這個技術透過調整哈希種子,使得在rehash的時候鍵值對能夠更均勻地分佈在新的桶數組中,從而減少哈希碰撞。

  1. 內建的偏向鎖定

Golang在map中使用了一種叫做偏向鎖定的鎖定機制。偏向鎖是一種最佳化技術,當鎖只被一個go例程存取時,它將使用這個goroutine的執行緒ID進行加鎖。這樣,當這個go例程需要對鎖進行解鎖或重新加鎖時,不需要進行線程切換,因為任何其他的go例程都不會訪問這個鎖。

總結

Golang中map的底層資料結構是雜湊表,它的桶數組使用randomized-hashing技術對鍵值對進行rehash,並使用偏向鎖定機制進行加鎖和解鎖。這些實作細節使得Golang中的map在一些常見的資料結構操作中表現出了非常出色的效能。

以上是golang map的實作講解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
go语言有没有缩进go语言有没有缩进Dec 01, 2022 pm 06:54 PM

go语言有缩进。在go语言中,缩进直接使用gofmt工具格式化即可(gofmt使用tab进行缩进);gofmt工具会以标准样式的缩进和垂直对齐方式对源代码进行格式化,甚至必要情况下注释也会重新格式化。

go语言为什么叫gogo语言为什么叫goNov 28, 2022 pm 06:19 PM

go语言叫go的原因:想表达这门语言的运行速度、开发速度、学习速度(develop)都像gopher一样快。gopher是一种生活在加拿大的小动物,go的吉祥物就是这个小动物,它的中文名叫做囊地鼠,它们最大的特点就是挖洞速度特别快,当然可能不止是挖洞啦。

聊聊Golang中的几种常用基本数据类型聊聊Golang中的几种常用基本数据类型Jun 30, 2022 am 11:34 AM

本篇文章带大家了解一下golang 的几种常用的基本数据类型,如整型,浮点型,字符,字符串,布尔型等,并介绍了一些常用的类型转换操作。

一文详解Go中的并发【20 张动图演示】一文详解Go中的并发【20 张动图演示】Sep 08, 2022 am 10:48 AM

Go语言中各种并发模式看起来是怎样的?下面本篇文章就通过20 张动图为你演示 Go 并发,希望对大家有所帮助!

go语言是否需要编译go语言是否需要编译Dec 01, 2022 pm 07:06 PM

go语言需要编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言,也就说Go语言程序在运行之前需要通过编译器生成二进制机器码(二进制的可执行文件),随后二进制文件才能在目标机器上运行。

tidb是go语言么tidb是go语言么Dec 02, 2022 pm 06:24 PM

是,TiDB采用go语言编写。TiDB是一个分布式NewSQL数据库;它支持水平弹性扩展、ACID事务、标准SQL、MySQL语法和MySQL协议,具有数据强一致的高可用特性。TiDB架构中的PD储存了集群的元信息,如key在哪个TiKV节点;PD还负责集群的负载均衡以及数据分片等。PD通过内嵌etcd来支持数据分布和容错;PD采用go语言编写。

聊聊Golang自带的HttpClient超时机制聊聊Golang自带的HttpClient超时机制Nov 18, 2022 pm 08:25 PM

​在写 Go 的过程中经常对比这两种语言的特性,踩了不少坑,也发现了不少有意思的地方,下面本篇就来聊聊 Go 自带的 HttpClient 的超时机制,希望对大家有所帮助。

golang map怎么删除元素golang map怎么删除元素Dec 08, 2022 pm 06:26 PM

删除map元素的两种方法:1、使用delete()函数从map中删除指定键值对,语法“delete(map, 键名)”;2、重新创建一个新的map对象,可以清空map中的所有元素,语法“var mapname map[keytype]valuetype”。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器