Go函数参数始终值传递,基本类型和结构体传副本不改变原值,需用指针修改;slice、map、channel虽为值传递,但拷贝的指针可修改底层数据,重新赋值则不影响原变量。

Go语言中的函数参数传递始终采用值传递的方式,也就是说,函数接收到的是原始数据的副本。无论传入的是基本类型、指针、结构体还是引用类型(如slice、map、channel),本质都是拷贝值。但根据类型的不同,这种“拷贝”带来的行为表现会有所差异。
基本类型与结构体:完全副本
对于int、string、bool等基本类型以及自定义结构体,值传递意味着函数内部操作的是变量的完整拷贝,原变量不会被修改。
例如:
func modifyValue(x int) { x = 100}// 调用后原变量不变a := 10modifyValue(a) // a 仍为 10
如果想在函数中修改原始结构体,需要传入其指针:
func updatePerson(p *Person) { p.Name = "Alice"}// 原结构体被修改person := Person{Name: "Bob"}updatePerson(&person)
slice、map、channel:引用语义的值传递
虽然slice、map、channel底层由指针实现,但它们本身是引用类型。传参时仍是值传递——拷贝的是包含指针的结构体(如slice的array指针、长度和容量),因此函数内可以修改其所指向的数据。
立即学习“go语言免费学习笔记(深入)”;
比如:
func appendToSlice(s []int) { s = append(s, 4)}// 外部slice不会变长(因为s是副本)data := []int{1,2,3}appendToSlice(data) // data 仍为 [1,2,3]func modifyMap(m map[string]int) { m["key"] = 99}// 外部map会被修改m := make(map[string]int)modifyMap(m) // m 现在包含 key:99
注意:虽然能修改map内容或slice元素,但如果重新赋值slice(如make或append导致扩容并生成新底层数组),则不影响原slice。
指针传递:共享同一地址
当参数是指针类型时,传递的是地址的拷贝。多个指针副本仍指向同一块内存,因此函数内可通过该指针修改原始数据。
这是实现“模拟引用传递”的常用方式,尤其适用于大型结构体,避免复制开销。
建议:小对象(如int、bool)直接传值即可大结构体建议传指针,提升性能需要修改原值时使用指针参数不确定是否修改时,优先考虑语义清晰性基本上就这些。理解值传递的本质,再结合类型的底层结构,就能准确预测参数行为。
以上就是Golang如何处理函数参数传递的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1413489.html
微信扫一扫
支付宝扫一扫