func main() {
arr := [3]int{1, 2, 3}
arr2 := arr
arr3 := &arr
fmt.Printf("原数组:%v
", arr)
fmt.Printf("赋值方式复制的数组:%v
", arr2)
fmt.Printf("引用方式复制的数组:%v
", *arr3)
}
func main() {
arr := [3]int{1, 2, 3}
arr2 := arr
arr3 := &arr
fmt.Printf("原数组:%v
", arr)
fmt.Printf("赋值方式复制的数组:%v
", arr2)
fmt.Printf("引用方式复制的数组:%v
", *arr3)
arr[1] = 1000
fmt.Printf("改变后原数组:%v
", arr)
fmt.Printf("改变后赋值方式复制的数组:%v
", arr2)
fmt.Printf("改变后引用方式复制的数组:%v
", *arr3)
}
要理解这个关系很简单,把这段代码画个底层结构图就明白了:arr2获得的是arr的数据副本,也就是说赋值方式是复制了原数组的底层数据; 而arr3获得的是arr地址的副本,即引用赋值的方式复制的是地址,这个地址指向的还是原来的数据。 所以也就出现了,当arr中原数据被修改,直接赋值而来的数组arr2不受影响,而引用赋值获得的数组arr3也跟着改变了。
另外如果你操作的是切片,那么还真有个内置的方法可以完成复制。
func main() {
arr2 := []int{1, 2, 3}
arr3 := []int{4,5,6}
fmt.Printf("复制前的数组:%v
", arr2)
copy(arr2, arr3)
fmt.Printf("复制后的数组:%v
", arr2)
}
通过copy函数,将底层数据进行了复制替换,所以新的切片也不会受原切片的影响。 针对复制拷贝总结如下: 如果复制数组,可以直接通过赋值进行复制; 如果复制切片,可以直接使用copy();