package main
import "fmt"
func main() {
arr1 := [11]int{1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11}
slice1 := arr1[:4] //从头开始下标可以不用写,第二个参数不包含末尾
slice2 := arr1[1:] //从下标1 “2”开始取到末尾
slice3 := arr1[3:8] //两个索引 取值范围是从star[index]开始到end[index]-1 的值
slice4 := arr1[:] //取所有
fmt.Println("arr1的内容:", arr1)
fmt.Printf("arr1的引用地址:%p\n", &arr1) //0xc00001a180
fmt.Printf("长度:%d容量:%d\n", len(arr1), cap(arr1)) //0xc00001a180
fmt.Println("=================================")
fmt.Println("slice1的内容:", slice1)
fmt.Printf("slice1的地址:%p\n", slice1) //0xc00001a180
fmt.Printf("slice1长度:%d slice1容量:%d\n", len(slice1), cap(slice1))
fmt.Println("=================================")
fmt.Println("slice2的内容:", slice2)
fmt.Printf("slice2的地址:%p\n", slice2) //0xc00001a188
fmt.Printf("slice2长度:%d slice2容量:%d\n", len(slice2), cap(slice2))
fmt.Println("=================================")
fmt.Println("slice3的内容:", slice3)
fmt.Printf("slice3的地址:%p\n", slice3) //0xc00001a198
fmt.Printf("slice3长度:%d lice3容量:%d\n", len(slice3), cap(slice3))
fmt.Println("=================================")
fmt.Println("slice4的内容:", slice4)
fmt.Printf("slice4的地址:%p\n", slice4) //0xc00001a180
fmt.Println("=================================")
/* 输出结果自行研究
arr1的内容: [1 2 3 4 5 6 7 8 9 10 11]
arr1的引用地址:0xc000082060
长度:11容量:11
=================================
slice1的内容: [1 2 3 4]
slice1的地址:0xc000082060
slice1长度:4 slice1容量:11
=================================
slice2的内容: [2 3 4 5 6 7 8 9 10 11]
slice2的地址:0xc000082068
slice2长度:10 slice2容量:10
=================================
slice3的内容: [4 5 6 7 8]
slice3的地址:0xc000082078
slice3长度:5 lice3容量:8
=================================
slice4的内容: [1 2 3 4 5 6 7 8 9 10 11]
slice4的地址:0xc000082060
=================================
*/
}
总结:
从上面案例中能够看出来切片会造成容量的更改,那么长度更改后,相应的引用地址也会发生变化,
如果从索引0 开始切片,那么容量是不会产生变化的,如果从其他索引开始切片的话那么他的容量是起始位到结束位的个数, 那么它底层数组的容量将会改变,引用地址就会发生变化