数组传参是值传递,函数内修改不影响原数组;切片传参共享底层数组,修改通常影响原切片,但扩容可能导致底层数组分离,从而不影响原切片。

在Golang中,数组和切片虽然看起来相似,但在作为函数参数传递时行为有显著区别。理解这些差异对编写高效、正确的代码非常重要。
数组是值传递
当数组作为函数参数传入时,Go会创建整个数组的副本。这意味着函数内部对数组的修改不会影响原始数组。
例如:
arr[0] = 999
}
func main() {
a := [3]int{1, 2, 3}
modifyArray(a)
fmt.Println(a) // 输出: [1 2 3]
}
这里,a 的值没有改变,因为传入的是副本。
立即学习“go语言免费学习笔记(深入)”;
切片是引用传递(本质是共享底层数组)
切片作为参数传递时,虽然也是值传递,但传递的是切片头的副本(包含指向底层数组的指针、长度和容量)。因此,函数内通过该指针对底层数组的修改会影响原始切片。
例如:
func modifySlice(s []int) {s[0] = 999
}
func main() {
slice := []int{1, 2, 3}
modifySlice(slice)
fmt.Println(slice) // 输出: [999 2 3]
}
原始切片内容被修改,因为它们共享同一底层数组。
注意事项:切片扩容可能打破共享
如果函数中对切片进行了扩容操作(如append导致容量不足),可能会生成新的底层数组,此时修改不会影响原切片。
示例:
func appendSlice(s []int) {s = append(s, 4)
s[0] = 888
}
func main() {
slice := []int{1, 2, 3}
appendSlice(slice)
fmt.Println(slice) // 输出: [1 2 3],未受影响
}
append可能导致底层数组更换,原切片不受影响。
基本上就这些。数组传参安全但开销大,适合小数据;切片高效但需注意共享带来的副作用。根据场景选择合适类型即可。










