在golang中,切片長度就是切片中元素的數(shù)量;切片容量是從創(chuàng)建切片的索引開始的底層數(shù)組中元素的數(shù)量,即從切片的第一個元素開始數(shù),到其底層數(shù)組元素末尾的個數(shù)。切片的長度與容量是可以計算的,內(nèi)置方法len()可獲取長度,cap()可獲取容量;在使用切片的過程中,如果使用append()讓切片的長度大于了切片的容量,那么切片的容量會以雙倍的形式自動擴容。
本教程操作環(huán)境:windows7系統(tǒng)、GO 1.18版本、Dell G3電腦。
Go 語言 的 切片 擁有長度和容量。
-
切片的長度是切片中元素的數(shù)量
-
切片的容量是從創(chuàng)建切片的索引開始的底層數(shù)組中元素的數(shù)量,即從它的第一個元素開始數(shù),到其底層數(shù)組元素末尾的個數(shù)。
切片是可索引的,并且可以由len()方法獲取長度,切片提供了計算容量的方法cap(),可以測量切片最長可以達到多少。我們在使用切片的過程中,如果使用 append 使切片的長度大于了切片的容量,那么切片的容量會以雙倍的形式自動擴容。
切片實際的是獲取數(shù)組的某一部分,len切片<=cap切片<=len數(shù)組
cap()的結(jié)果決定了切片截取的注意細節(jié)
var sTest01 []int func sliceTest01() { fmt.Printf("%T n cap(sTest01) = %v n", sTest01, cap(sTest01)) sTest01 = append(sTest01, 1, 2, 3, 4, 5, 6) fmt.Printf("%T n cap(sTest01) = %v n", sTest01, cap(sTest01)) }
運行結(jié)果:
[]int cap(sTest01) = 0 []int cap(sTest01) = 6
由此可以看到,在初始時,切片長度為0,在添加元素后,實際長度為6
證明數(shù)組是值類型,切片是引用類型的例子:
func sliceTest02() { x := [...]int{1, 2, 3, 4, 5, 6} y := []int{100, 200, 300, 400} w := x z := y w[0] = 777 z[0] = 999 fmt.Println("x = ", x, "nw = ", w) fmt.Println("y = ", y, "nz = ", z) }
運行結(jié)果:
x = [1 2 3 4 5 6] w = [777 2 3 4 5 6] y = [999 200 300 400] z = [999 200 300 400]
從運行結(jié)果可以看到,z的改變影響到了y的值,說明切片是引用類型。
slice沒有自己的任何數(shù)據(jù),它只是底層數(shù)組的一個引用,對slice所做的任何修改都將反映在底層數(shù)組中數(shù)組是值類型,而切片是引用類型
func sliceCap() { arr := [...]string{"a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k"} fmt.Println("cap(arr) = ", cap(arr), arr) //截取數(shù)組,形成切片 s1 := arr[2:8] fmt.Printf("%T n", s1) fmt.Println("cap(s1) = ", cap(s1), s1) //截取數(shù)組,形成切片 s2 := arr[4:7] fmt.Printf("%T n", s2) fmt.Println("cap(s2) = ", cap(s2), s2) //截取數(shù)組,形成切片 s3 := s1[3:9] fmt.Printf("%T n", s3) fmt.Println("cap(s3) = ", cap(s3), s3) //截取數(shù)組,形成切片 s4 := s2[4:7] fmt.Printf("%T n", s4) fmt.Println("cap(s4) = ", cap(s4), s4) //證明切片是引用類型 s4[0] = "x" fmt.Println(arr, s1, s2, s3, s4) }
運行結(jié)果:
cap(arr) = 11 [a b c d e f g h i j k] []string cap(s1) = 9 [c d e f g h] []string cap(s2) = 7 [e f g] []string cap(s3) = 6 [f g h i j k] []string cap(s4) = 3 [i j k] [a b c d e f g h x j k] [c d e f g h] [e f g] [f g h x j k] [x j k]
由結(jié)果我們可以看到,切片的截取只能生成切片,如果內(nèi)容不夠截取,會從底層數(shù)組給出后面的值。如果長度不夠,會報錯。
判斷一個切片是否為空,如果直接使用nil來判斷,是不準確的。
Golang允許len為0但是cap不為0,或者兩者都為的0的切片,所以一般通過len獲取切片長度來判斷是否為空切片,而不是直接將切片和nil做直接的比較。
【