- 关于golang的slice我认为是go几个特点之一,它充分得改善了数组的几个局限地方,本文简单分析slice使用过程中你会遇到的几个问题:
我们看以下例子:
sliceA:=[]int{1,2,3}
sliceB:=sliceA[0:2]
sliceA[0]=4
fmt.Println(sliceB)//此处输出什么?
以上代码说明,slice的赋值操作是引用类型(地址拷贝)更改原slice后自己会受影响。那么如果你想要不受影响,可以选择复制操作:
sliceA:=[]int{1,2,3}
sliceB:=make([]int,len(sliceA))
copy(sliceA,sliceB)
注意copy操作需要对操作对象先创建地址空间。
我们看下面的问题:
sliceA:=[]int{1,2,3}
sliceB:=append(sliceA,4,5)
sliceC:=sliceB[0:3]
fmt.Println(len(sliceA),len(sliceB),len(sliceC))//输出什么?
fmt.Println(cap(sliceA),cap(sliceB),cap(sliceC))//输出什么?
正确结果:
3 5 3
3 6 6
分析以上你可以知道,append操作slice底层数组容量会成倍增加,len求的是slice长度,就是实际有值的长度,cap是求的容量。go中容量的概念需要想一想的。
sliceC被赋值时容量是和sliceB相等的,但是长度不同。
本文来自:易云blog