首先来看一个例子:
package main
import "fmt"
func main() {
a := make([]int, 6)
printSlice("a", a)
b := make([]int, 0, 6)
printSlice("b", b)
c := b[:2]
printSlice("c", c)
d := c[2:5]
printSlice("d", d)
}
func printSlice(s string, x []int) {
fmt.Printf("%s len=%d cap=%d %v\n",
s, len(x), cap(x), x)
}
========== 输出结果 =============
a len=6 cap=6 [0 0 0 0 0 0]
b len=0 cap=6 []
c len=2 cap=6 [0 0]
d len=3 cap=4 [0 0 0]
说明:
make([]T, len, cap), 参数1表示类型,参数2表示长度,参数3表示容量
长度是指当前切片的长度;
容量是指的切片底层数组的长度;
因此,上述例子中 a,b的输出毋庸置疑;
数组:
根据计算逻辑, 切片b,c , d的底层数组均是同一个
切片b:
c切片
d切片
由于当切片长度大于底层数组长度时,go会重新申请一个新的底层数组来存储数据
;因此:
对于切片C,D来说,基于目前数组的容量 = 切片长度 + 切片在数组映射区间之后的长度
因此:切片C的容量为6, 切片D的容量为4