数组传参为值传递,函数内修改不影响原数组;切片传参共享底层数组,元素修改会影响原切片,但扩容可能导致底层数组分离,需通过返回值获取新切片。

在Go语言中,数组和切片是两种常见的数据结构,但在函数传参时的行为有显著差异。理解它们的传递方式对编写高效、正确的程序至关重要。
Go中的数组是固定长度的,当把数组作为参数传递给函数时,实际上传递的是数组的副本。
这意味着函数内部对数组的修改不会影响原始数组。
示例:func modifyArray(arr [3]int) {
arr[0] = 999
}
arr := [3]int{1, 2, 3}
modifyArray(arr)
fmt.Println(arr) // 输出:[1 2 3],原数组未改变
如果确实需要在函数中修改原数组,可以传递指针:
立即学习“go语言免费学习笔记(深入)”;
func modifyArrayPtr(arr *[3]int) {
arr[0] = 999
}
modifyArrayPtr(&arr)
fmt.Println(arr) // 输出:[999 2 3]
切片本身是一个引用类型,它包含指向底层数组的指针、长度和容量。当切片作为参数传入函数时,虽然也是值传递(复制切片头),但其内部指针仍指向相同的底层数组。
因此,函数内对切片元素的修改会影响原始切片。
示例:func modifySlice(s []int) {
s[0] = 888
}
slice := []int{1, 2, 3}
modifySlice(slice)
fmt.Println(slice) // 输出:[888 2 3],原切片被修改
注意:如果在函数中对切片进行扩容操作(如append导致超出容量),可能会生成新的底层数组,此时后续修改不影响原切片。
func appendSlice(s []int) {
s = append(s, 4) // 若触发扩容,则s指向新数组
s[0] = 777
}
appendSlice(slice)
fmt.Println(slice) // 可能仍是 [888 2 3],不受影响
若希望函数内的append操作不影响原切片,无需特别处理。但若需将扩展后的切片返回使用,应显式返回新切片。
func safeAppend(s []int, val int) []int {
return append(s, val)
}
slice = safeAppend(slice, 4)
若想避免函数内意外修改原数据,可创建副本再操作:
func copyAndModify(s []int) {
newSlice := make([]int, len(s))
copy(newSlice, s)
newSlice[0] = 666 // 修改副本
}
• 数组传参是值传递,开销大且不修改原数组,一般不推荐直接传数组。
• 切片传参本质上共享底层数组,适合大规模数据传递。
• 需要修改切片内容时,直接传切片即可。
• 涉及append可能导致扩容时,注意是否需要返回新切片。
• 若需隔离数据,手动创建切片副本。
基本上就这些。掌握数组和切片的传参机制,能有效避免数据意外修改或性能问题。
以上就是Golang如何处理数组与切片传参_Golang数组切片函数传参方法汇总的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号