溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

golang切片擴(kuò)容規(guī)則的實(shí)現(xiàn)方法

發(fā)布時(shí)間:2021-03-03 11:26:57 來源:億速云 閱讀:194 作者:小新 欄目:開發(fā)技術(shù)

這篇文章主要介紹golang切片擴(kuò)容規(guī)則的實(shí)現(xiàn)方法,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

golang擴(kuò)容規(guī)則

golang切片擴(kuò)容規(guī)則的實(shí)現(xiàn)方法

舉個(gè)例子來演示下

package main

import (
"fmt"
)
func main() {
arr1 := [4]int{1,2,3,4}
//此時(shí)slice1為[1,2,3] 長(zhǎng)度為3,容量為4
slice1 :=arr1[:3]
fmt.Println(slice1,len(slice1),cap(slice1))
slice1 = append(slice1,5000,6000)
fmt.Println(slice1,len(slice1),cap(slice1))
}

此時(shí)容量由原來的4擴(kuò)容到了8,你以為就是簡(jiǎn)單的2倍嗎?那你可真理解錯(cuò)了,你得知道他背后擴(kuò)容的原因,我來給你計(jì)算下
1、原來的容量為4,追加了5000,6000后變?yōu)榱?個(gè),此時(shí)4*2>6,滿足了腦圖中的第二種情況,并且元素個(gè)數(shù)小于1024,先擴(kuò)容2倍
2、由于64位操作系統(tǒng)下,一個(gè)int類型占8個(gè)字節(jié),所以8*8=64
3、此時(shí)匹配操作系統(tǒng)預(yù)先分配好的內(nèi)存規(guī)格,規(guī)則正好匹配了64,所以用64/8=8,所以擴(kuò)容后的容量為8

golang切片擴(kuò)容規(guī)則的實(shí)現(xiàn)方法

咱們?cè)賮硪粋€(gè)例子看你是否真正理解了他的擴(kuò)容規(guī)則, 這個(gè)例子最后容量為10

package main

import (
	"fmt"
)
func main() {
	arr1 := [4]int{1,2,3,4}
	//此時(shí)slice1為[1,2,3] 長(zhǎng)度為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))
}

golang切片擴(kuò)容規(guī)則的實(shí)現(xiàn)方法

···
慌不慌,你是不懂了嗎?不懂我給你好好算一下
1??原來容量是4,此時(shí)追加了5個(gè)元素,變?yōu)榱?
2??4*2<9,滿足腦圖中的第一個(gè)條件,由于int類型在64位操作系統(tǒng)下占用8個(gè)字節(jié),所以用9*8=72
3??所以此時(shí)需要匹配的內(nèi)存規(guī)格為80
4??用80/8=10,所以此時(shí)容量為10

元素個(gè)數(shù)大于1024的我就不給你展示了,原理都是一樣的,認(rèn)認(rèn)真真看完之后擴(kuò)容規(guī)則肯定就懂了,不用再看其他的了

以上是“golang切片擴(kuò)容規(guī)則的實(shí)現(xiàn)方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI