濮阳杆衣贸易有限公司

主頁 > 知識庫 > golang切片擴容規(guī)則實現

golang切片擴容規(guī)則實現

熱門標簽:地圖標注免費定制店 不封卡外呼系統 重慶慶云企業(yè)400電話到哪申請 上海極信防封電銷卡價格 仙桃400電話辦理 湛江crm外呼系統排名 寧波語音外呼系統公司 宿遷便宜外呼系統代理商 鄭州智能語音電銷機器人價格

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,滿足了腦圖中的第二種情況,并且元素個數小于1024,先擴容2倍
2、由于64位操作系統下,一個int類型占8個字節(jié),所以8*8=64
3、此時匹配操作系統預先分配好的內存規(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*29,滿足腦圖中的第一個條件,由于int類型在64位操作系統下占用8個字節(jié),所以用9*8=72
3⃣️所以此時需要匹配的內存規(guī)格為80
4⃣️用80/8=10,所以此時容量為10

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

總結:切片擴容規(guī)則和你追加的元素個數有關
切片擴容和你匹配的操作系統分配的內存規(guī)格有關
和你定義的切片類型有關

到此這篇關于golang切片擴容規(guī)則實現的文章就介紹到這了,更多相關golang切片擴容 內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • 淺談Golang 切片(slice)擴容機制的原理

標簽:遼寧 物業(yè)服務 儋州 海南 安康 電子產品 西雙版納 青海

巨人網絡通訊聲明:本文標題《golang切片擴容規(guī)則實現》,本文關鍵詞  golang,切片,擴容,規(guī)則,實現,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《golang切片擴容規(guī)則實現》相關的同類信息!
  • 本頁收集關于golang切片擴容規(guī)則實現的相關信息資訊供網民參考!
  • 推薦文章
    温泉县| 思茅市| 赣州市| 罗定市| 温州市| 榆社县| 宜宾县| 瑞金市| 扶余县| 互助| 巴青县| 嘉兴市| 锡林郭勒盟| 本溪市| 神池县| 边坝县| 兴城市| 宜宾市| 峨边| 宽甸| 锡林浩特市| 连城县| 开远市| 都匀市| 白朗县| 若羌县| 修文县| 岳阳市| 夏津县| 宿州市| 凌源市| 米易县| 铜鼓县| 股票| 凌云县| 三都| 嵊泗县| 沐川县| 师宗县| 聂荣县| 阿拉善左旗|