Go 数组赋值的谜团:为什么修改复制的数组不影响原数组?

go 数组赋值的谜团:为什么修改复制的数组不影响原数组?

go 数组赋值的谜团

在 go 中,数组是一种固定长度的序列,存储相同类型的元素。当需要对数组进行赋值操作时,数组的取值方式决定了赋值的结果。

以代码为例:

a := [3]int{1, 2, 3}
a2 := a

for i := range a2 {
    a2[i] = 0
}

fmt.println(a) // 输出 [1 2 3]

令人惊讶的是,尽管我们对 a2 进行了修改,但打印 a 时仍然得到原始值 [1 2 3]。这是为什么呢?

值传递 vs 引用传递

在 go 中,数组是值类型。这意味着当一个变量赋值给另一个变量时,后者会获得源变量的副本。在我们的例子中,a2 := a 实际创建了数组 a 的一个副本。因此,对 a2 的修改不会影响原始数组 a。

切片引用

如果您希望 a2 与 a 引用同一数据,可以使用切片而不是数组赋值。切片是数组的一部分的动态大小视图。使用 a2 := a[:] 语法,a2 将成为 a 的引用,对其进行的任何修改都会影响原始数组。

修改后的代码:

a := [3]int{1, 2, 3}
a2 := a[:]

for i := range a2 {
    a2[i] = 0
}

fmt.Println(a) // 输出 [0 0 0]

现在,输出将是 [0 0 0],因为我们对 a2 的更改直接反映了原始数组 a。

以上就是Go 数组赋值的谜团:为什么修改复制的数组不影响原数组?的详细内容,更多请关注其它相关文章!