Go语言中函数参数为值传递,需用指针修改原值。通过&取地址传参,*解引用修改,如modifyValue(&num)可改变num;结构体指针传参避免复制并修改字段,如updatePerson(&person);需防范nil指针引发panic,应检查ptr!=nil再操作。

在Go语言中,函数参数默认是值传递,也就是说函数接收到的是参数的副本。如果想通过函数修改原始变量的值,就需要使用指针作为参数,实现类似“引用传递”的效果。
指针作为函数参数的基本用法
通过将变量的地址传入函数,函数内部可以通过指针直接访问和修改原变量的值。
示例代码:
func modifyValue(ptr *int) {
*ptr = 100
}
func main() {
num := 25
fmt.Println(“修改前:”, num) // 输出: 25
modifyValue(&num)
fmt.Println(“修改后:”, num) // 输出: 100
}
在这个例子中,&num 获取变量 num 的地址,传递给指针参数 *int 类型的函数。函数内部通过 *ptr = 100 解引用并修改原值。
立即学习“go语言免费学习笔记(深入)”;
结构体指针传参修改字段
对于结构体类型,使用指针传参可以避免复制整个结构体,同时允许函数修改其字段。
type Person struct {
Name string
Age int
}
func updatePerson(p *Person) {
p.Name = “Alice”
p.Age = 30
}
func main() {
person := Person{Name: “Bob”, Age: 25}
fmt.Printf(“修改前: %+vn”, person)
updatePerson(&person)
fmt.Printf(“修改后: %+vn”, person)
}
输出结果会显示 person 的字段被成功修改。这种方式高效且常见于实际开发中。
注意 nil 指针风险
使用指针时必须确保传入的指针非 nil,否则运行时会引发 panic。
建议在函数内部做空指针检查:
func safeUpdate(ptr *int) {
if ptr == nil {
fmt.Println(“指针为空,无法修改”)
return
}
*ptr = 42
}
调用时避免传入 nil,或确保指针已正确初始化。
基本上就这些。用指针传参是Go中修改原值的标准做法,理解解引用和地址操作是关键。不复杂但容易忽略细节。
以上就是Golang指针作为函数参数 实现引用传递修改原值的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1399400.html
微信扫一扫
支付宝扫一扫