如果可能的话,我试图使我的代码更具性能,以节省内存
我做了一些研究,但是找不到关于此特定案例的任何信息。
func createSlice() []int {
return s[]int{1,2,3}
}
func main() {
s2 := createSlice()
}
s2是一个带有其自身基础数组的全新切片吗?或者它是指向s的基础数组的切片?
答案 0 :(得分:2)
您必须了解Go Slices的标题。然后,您可以自己回答。
通过检出reflect.SliceHeader
类型来查看切片标头中的内容:
type SliceHeader struct {
Data uintptr
Len int
Cap int
}
实际上,Slice值是一个 header ,其中包含支持数组以及长度和容量。它包含一个指向实际存储的元素数组的指针。 slice值不包含元素(与数组不同)。
因此,当传递或返回切片时,将从此标头与指针一起传递或返回副本。该指针指向相同的后备数组。因此,如果您修改切片的元素,它也会同时修改支持的数组,因此所有切片(共享相同的支持的数组)也会得到更改。
因此,当您将切片传递给函数时,将从此标头(包括指针)进行复制,该指针将指向相同的后备数组。修改分片的元素意味着修改了后备数组的元素,因此共享同一后备数组的所有分片将“观察”更改。