go的数组和切片 go语言数组和切片
仓库传参是值传递,函数内修改不影响原切片;切片传参共享基础架构,通常会影响原切片,但扩容修改内容可能会导致基础架构分离,从而不影响原切片。
在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免费语言学习笔记(深入)”;切片是引用修改提交(本质上是共享批量复制)
切片作为参数提交时,虽然也是值批量提交,但提交的是切片头的副本(包含间接间接的指针、长度和容量)。因此,函数内通过该指针对间接复制的会影响原始切片。
例如:funcmodifySlice(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中仓库和预案作为函数传递时的差异的详细内容,更多请乐哥常识网其他相关参数!