Go 语言数组指针作为参数传递:浅拷贝和深拷贝的区别是什么?
go 语言数组指针作为参数传递的解读
在 golang 中,数组指针可以作为函数的参数传递,但需要注意以下不同情况:
浅拷贝传递(update1)
- update1 函数复制了一个新数组副本,它与原始数组是独立的。
- 对复制的数组进行修改不会影响原始数组。
深拷贝传递(update3)
- update3 函数通过指针传递了数组,指向同一块内存地址。
- 对指针数组进行修改会直接影响原始数组。
update2 的理解
update2 中,*p 被复制到一个新变量 a 中。这意味着 a 也只是一个数组副本,与原始数组独立。因此,该函数的预期行为与 update1 相同,对副本进行修改不会影响原始数组。
update4 的解读
update4 函数采用语法糖的形式,等同于 update3。两个函数都通过指针修改同一个内存地址。
示例
以下示例进一步展示了数组指针传递的差异:
package main import "fmt" func main() { a := [...]int{1, 2, 3} c := &a b := *c b[1] = 3 fmt.Println(a) fmt.Println(b) fmt.Printf("%p ", &a) fmt.Printf("%p ", &b) // 输出 // [1 2 3] // [1 3 3] // 0xc00010a078 // 0xc00010a090 }
该示例中:
- c 指向 a 的地址。
- b 是对 a 的深拷贝。
- b[1] 的修改会同时影响 a 和 b。
- a 和 b 的内存地址不同,表明它们是独立的数组。
以上就是Go 语言数组指针作为参数传递:浅拷贝和深拷贝的区别是什么?的详细内容,更多请关注其它相关文章!