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

在Golang中,数组和切片虽然看起来相似,但在作为函数参数传递时行为有显著区别。理解这些差异对编写高效、正确的代码非常重要。
数组是值传递
当数组作为函数参数传入时,Go会创建整个数组的副本。这意味着函数内部对数组的修改不会影响原始数组。
例如:
func modifyArray(arr [3]int) {
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可能导致底层数组更换,原切片不受影响。
基本上就这些。数组传参安全但开销大,适合小数据;切片高效但需注意共享带来的副作用。根据场景选择合适类型即可。
以上就是Golang中数组和切片作为函数参数传递时的差异的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1401958.html
微信扫一扫
支付宝扫一扫