首页 > 后端开发 > Golang > 正文

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

P粉602998670
发布: 2025-08-31 10:56:01
原创
998人浏览过
数组传参是值传递,函数内修改不影响原数组;切片传参共享底层数组,修改通常影响原切片,但扩容可能导致底层数组分离,从而不影响原切片。

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

在Golang中,数组和切片虽然看起来相似,但在作为函数参数传递时行为有显著区别。理解这些差异对编写高效、正确的代码非常重要。

数组是值传递

当数组作为函数参数传入时,Go会创建整个数组的副本。这意味着函数内部对数组的修改不会影响原始数组。

例如:

怪兽AI数字人
怪兽AI数字人

数字人短视频创作,数字人直播,实时驱动数字人

怪兽AI数字人 44
查看详情 怪兽AI数字人
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中数组和切片作为函数参数传递时的差异的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号