golang切片擴容規(guī)則實現(xiàn)
golang擴容規(guī)則
舉個例子來演示下
package main import ( "fmt" ) func main() { arr1 := [4]int{1,2,3,4} //此時slice1為[1,2,3] 長度為3,容量為4 slice1 :=arr1[:3] fmt.Println(slice1,len(slice1),cap(slice1)) slice1 = append(slice1,5000,6000) fmt.Println(slice1,len(slice1),cap(slice1)) }
此時容量由原來的4擴容到了8,你以為就是簡單的2倍嗎?那你可真理解錯了,你得知道他背后擴容的原因,我來給你計算下
1、原來的容量為4,追加了5000,6000后變?yōu)榱?個,此時4*2>6,滿足了腦圖中的第二種情況,并且元素個數(shù)小于1024,先擴容2倍
2、由于64位操作系統(tǒng)下,一個int類型占8個字節(jié),所以8*8=64
3、此時匹配操作系統(tǒng)預先分配好的內(nèi)存規(guī)格,規(guī)則正好匹配了64,所以用64/8=8,所以擴容后的容量為8
咱們再來一個例子看你是否真正理解了他的擴容規(guī)則, 這個例子最后容量為10
package main import ( "fmt" ) func main() { arr1 := [4]int{1,2,3,4} //此時slice1為[1,2,3] 長度為3,容量為4 slice1 :=arr1[:3] fmt.Println(slice1,len(slice1),cap(slice1)) slice1 = append(slice1,5000,6000,7000,8000,9000,10000) fmt.Println(slice1,len(slice1),cap(slice1)) }
···
慌不慌,你是不懂了嗎?不懂我給你好好算一下
1⃣️原來容量是4,此時追加了5個元素,變?yōu)榱?
2⃣️4*2<9,滿足腦圖中的第一個條件,由于int類型在64位操作系統(tǒng)下占用8個字節(jié),所以用9*8=72
3⃣️所以此時需要匹配的內(nèi)存規(guī)格為80
4⃣️用80/8=10,所以此時容量為10
···
元素個數(shù)大于1024的我就不給你展示了,原理都是一樣的,認認真真看完之后擴容規(guī)則肯定就懂了,不用再看其他的了
總結(jié):切片擴容規(guī)則和你追加的元素個數(shù)有關
切片擴容和你匹配的操作系統(tǒng)分配的內(nèi)存規(guī)格有關
和你定義的切片類型有關
到此這篇關于golang切片擴容規(guī)則實現(xiàn)的文章就介紹到這了,更多相關golang切片擴容 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
在?Golang?中使用?Cobra?創(chuàng)建?CLI?應用
這篇文章主要介紹了在?Golang?中使用?Cobra?創(chuàng)建?CLI?應用,來看下?Cobra?的使用,這里我們使用的?go1.13.3?版本,使用?Go?Modules?來進行包管理,需要的朋友可以參考下2022-01-01GoLang strings.Builder底層實現(xiàn)方法詳解
自從學習go一個月以來,我多少使用了一下strings.Builder,略有心得。你也許知道它,特別是你了解bytes.Buffer的話。所以我在此分享一下我的心得,并希望能對你有所幫助2022-10-10