Golang中数组和切片作为函数参数传递时的差异

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

golang中数组和切片作为函数参数传递时的差异

在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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月15日 18:16:13
下一篇 2025年12月15日 18:16:25

相关推荐

发表回复

登录后才能评论
关注微信