go語言中切片的長度和容量的區別
切片的長度,顯而易見的就是元素的個數,根據元素的個數進行返回具體的長度。
切片的長度,更像是一個警戒值,如果長度與容量相等,就會進行容量的擴容,比如
des :=make([]int , 3 , 5) //此時,長度為3,容量為5,但是如果使用append(), //切片長度會變為4,再次使用append()切片長度變為5。 //此時,切片長度與容量相同,此時,切片的容量增大變為cap = len*2
也就是通過一個容量設警戒值,如果等於警戒值,就會自動將切片進行擴容
補充:Go語言中切片的長度與容量的變化
在學習go語言的切片信息時,發現切片的容量變化非常讓人摸不著頭腦,為瞭更記憶深刻就寫下瞭這篇,如有錯誤之處,請大傢指正
一,當前切片的長度與容量相等情況:
package main import ( "fmt" ) func main() { numbers := []int{0,1,2} printSlice(numbers) //通過append給numbers增加信息,如果當前切片的長度與容量相等,增加信息的長度小於等於原來的長度, 那麼切片的長度變為相加之和,容量變為原來的2倍(圖片一的第二行結果) numbers = append(numbers, 10,5,6) printSlice(numbers) //通過append給numbers增加信息,如果當前切片A的長度與容量相等,增加信息B的長度大於切片A原來的長度, 那麼切片的長度變為相加之和,容量變為:B長度+A長度+(B長度-A長度)%2(圖片一的第三行結果) numbers = append(numbers, 12,13,15,16,17,18,19,20,21,22,23) printSlice(numbers) } func printSlice(x []int){ fmt.Printf("len=%d cap=%d slice=%v\n",len(x),cap(x),x) }
圖片一:
二,如果當前切片的長度小於容量情況:
增加信息的長度與當前長度和小於等於容量
func main() { /* 創建切片 */ numbers := []int{0,1,2} printSlice(numbers) numbers = append(numbers, 10,5) printSlice(numbers) //通過append給numbers增加信息,如果當前切片的長度小於容量,增加信息的長度與當前長度和小於等於容量, 那麼numbers的長度變為相加之和,容量不變(圖片二的第三行結果) numbers = append(numbers, 11) printSlice(numbers) }
圖片二:
增加信息B的長度與當前A的長度大於A容量並且小於A容量的2倍
func main() { /* 創建切片 */ numbers := []int{0,1,2} printSlice(numbers) numbers = append(numbers, 10,5) printSlice(numbers) //通過append給numbers增加信息,如果當前切片A的長度小於容量,增加信息B的長度與當前A的長度大於A容量並且小於A容量的2倍, 那麼numbers的長度變為相加之和,容量變為:A容量*2(圖片三的第三行結果) numbers = append(numbers, 11,12) printSlice(numbers) }
圖片三:
增加信息B的長度與當前A的長度大於A容量的2倍
func main() { /* 創建切片 */ numbers := []int{0,1,2} printSlice(numbers) numbers = append(numbers, 10,5) printSlice(numbers) //通過append給numbers增加信息,如果當前切片A的長度小於容量,增加信息B的長度與當前A的長度大於A容量的2倍, 那麼numbers的長度變為相加之和C。容量變為:B長度+A長度+(B長度-A長度)%2(圖片四的第三行結果) numbers = append(numbers, 11,12,13,15,16,17,18,19,20) printSlice(numbers) }
圖片四:
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。
推薦閱讀:
- go語言求任意類型切片的長度操作
- Go語言–切片(Slice)詳解
- 詳解Go語言Slice作為函數參數的使用
- GO語言基本類型String和Slice,Map操作詳解
- Go語言切片前或中間插入項與內置copy()函數詳解