搜尋
首頁後端開發Golanggo語言擴容法有哪幾種
go語言擴容法有哪幾種Jan 16, 2023 pm 04:11 PM
golanggo語言

go語言擴容方法有:1、Slice擴容,在使用append向Slice追加元素時,如果Slice空間不足,將會觸發Slice擴容;2、Map擴容。觸發Map擴容的條件有二:1、負載因子大於6.5時,也即平均每個bucket儲存的鍵值對達到6.5個;2、overflow數量大於2^15時,也即overflow數量超過32768時。

go語言擴容法有哪幾種

本教學操作環境:windows7系統、GO 1.18版本、Dell G3電腦。

Slice擴容

觸發

使用append向Slice追加元素時,如果Slice空間不足,將會觸發Slice擴容

原理

擴容實際上是重新分配一塊更大的內存,將原Slice資料拷貝進新Slice,然後返回新Slice,擴容後再將資料追加進去。

機制

V1.8之前:

擴充容量的選擇遵循下列規則:

  • 如果原Slice容量小於1024 ,則新Slice容量將擴大為原來的2倍;
  • 如果原Slice容量大於等於1024,則新Slice容量將擴大為原來的1.25倍;
// 1.17及以前的版本中
// old指切片的旧容量, cap指期望的新容量
func growslice(old, cap int) int {
    newcap := old
    doublecap := newcap + newcap
    // 如果期望容量大于旧容量的2倍,则直接使用期望容量作为最终容量
    if cap > doublecap {
        newcap = cap
    } else {
        // 如果旧容量小于1024,则直接翻倍
        if old <h3 id="V-之後">V1 .8之後:</h3><p>新擴容容量的選擇遵循以下規則:(擁有更平滑的擴容係數)</p>
  • 如果原Slice容量小於256,則新Slice容量將擴大為原來的2倍;
  • 如果原Slice容量大於等於256,則新Slice容量將擴大為原來的  新容量= (原容量3*256)/4
// 只关心扩容规则的简化版growslice
func growslice(old, cap int) int {
    newcap := old
    doublecap := newcap + newcap
    if cap > doublecap {
        newcap = cap
    } else {
        const threshold = 256 // 不同点1
        if old <h2 id="strong-Map擴容-strong"><strong>Map擴容</strong></h2><p>觸發<em>擴容</em>的條件有二:</p>
  • 負載因子> 6.5時,也即平均每個bucket儲存的鍵值對達到6.5個。 增量擴容

  • overflow數量 > 2^15時,也即overflow數量超過32768時。 等量擴充功能/重排

注意:建立溢位桶不屬於擴容機制

#增量擴容

  • 當負載因子過大時,新開啟buckets空間,bucket數量為之前的2 倍
  • 新空間被buckets引用,先前的舊空間被oldbuckets引用
  • 之後逐漸將oldbuckets中的資料搬遷到新開闢的buckets空間中去

考慮到如果map儲存了數以億計的key -value,一次搬遷將會造成比較大的延時,Go採用逐步搬遷策略,即每次訪問map時都會觸發一次搬遷,每次搬遷2個鍵值對當oldbuckets中的鍵值對全部搬遷完畢後,刪除oldbuckets。

下圖展示了包含一個bucket滿載的map(為了描述方便,圖中bucket省略了value區域):

##目前map儲存了7個鍵值對,只有1個bucket。此時負載因子為7 > 6.5。再次插入資料時將會觸發

擴容操作,擴容之後再將新插入鍵寫入新的bucket。注意,因為負載因子的觸發,不是創建溢出桶

當第8個鍵值對插入時,將會觸發

擴容擴容後示意圖如下:

後續對map的存取操作會觸發遷移,並將oldbuckets中的鍵值對逐步的搬遷過來。

搬遷完成後的示意圖如下:

資料搬遷過程中原bucket中的鍵值對將存在於新bucket的前面,新插入的鍵值對將存在於新bucket的後面。

等量擴容/重排

所謂等量

擴容,其實並不是擴大容量,buckets數量不變,重新做一遍類似增量擴容的搬遷​​動作,把鬆散的鍵值對重新排列一次,以使bucket的使用率更高,進而保證更快的訪問。 在極端場景下,例如不斷地增刪,而鍵值對正好集中在一小部分的bucket,這樣會造成overflow的bucket數量增多,但負載因子又不高,從而無法執行增量搬遷的情況,如下圖所示:

上圖可見,overflow的bucket大部分是空的,存取效率會很差。此時進行一次等量

擴容,即buckets數量不變,經過重新組織後overflow的bucket數量會減少,即節省了空間又會提高訪問效率。

【相關推薦:

Go影片教學程式設計教學

以上是go語言擴容法有哪幾種的詳細內容。更多資訊請關注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 并发,希望对大家有所帮助!

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语言编写。

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

go语言需要编译。Go语言是编译型的静态语言,是一门需要编译才能运行的编程语言,也就说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尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

Safe Exam Browser

Safe Exam Browser

Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

SublimeText3 英文版

SublimeText3 英文版

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

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境