电话
400 9058 355
传值函数无法修改原始变量,因为Go中所有参数均为值传递,形参是实参的副本;要修改原始变量需用指针:函数声明int参数,调用时传&n,函数内用p赋值。
Go 中所有参数都是值传递,包括 int、
string、struct 等值类型。这意味着函数内对形参的赋值操作只影响副本,不影响调用方的原始变量。
常见错误现象:
func addOne(x int) {
x = x + 1 // 这里改的是副本
}
n := 5
addOne(n)
fmt.Println(n) // 输出 5,不是 6
string 虽然底层包含指针,但它是不可变类型,任何“修改”都生成新字符串,原变量不变*T 和 & 正确修改值要修改原始变量,需在函数签名中声明指针类型参数,并在调用时用 & 取地址;函数体内用 * 解引用后赋值。
实操示例:
func increment(p *int) {
*p = *p + 1 // 解引用后修改原始内存位置的值
}
n := 10
increment(&n) // 传入 n 的地址
fmt.Println(n) // 输出 11
&n 获取变量 n 在内存中的地址,类型是 *int
*p 表示“取指针 p 所指向的值”,可读可写nil 指针并解引用(如 *p),会 panic:"invalid memory address or nil pointer dereference"&42),Go 编译器会报错new(T) 和 &T{} 创建指针的区别
两者都能获得指向零值的指针,但语义和适用场景不同。
new(T) 总是返回指向 T 类型零值的指针,适用于任意类型,包括基本类型和自定义类型&T{} 是取结构体/数组/切片字面量地址,只能用于复合类型(且要求字段可省略或全显式初始化)new(int) → *int 指向 0;&int{42} ❌ 编译失败(不能对基本类型字面量取地址)new(MyStruct) 和 &MyStruct{} 效果等价,但后者支持字段初始化:&MyStruct{Name: "a"}
方法接收者是否用指针,直接决定能否修改调用者本身,也影响性能和接口实现行为。
type User struct{ Name string },若只有 func (u User) SetName(s string)(值接收者),则 *User 类型变量不能赋值给含 SetName 方法的接口变量真正容易被忽略的是:指针接收者方法可以被值类型变量调用(Go 自动取地址),但前提是该值是可寻址的——局部变量、切片元素、结构体字段可以;而字面量、函数返回值、map 值等不可寻址,此时调用指针接收者方法会编译失败。
邮箱:8955556@qq.com
Q Q:8955556
本文详解如何将Go官方present工具(用于生成HTML5...
PySNMP在不同版本中对SNMP错误状态(errorSta...
time.Sleep仅阻塞当前goroutine,其他gor...
PHPfopen()创建含特殊符号的文件名失败主因是操作系统...
WooCommerce中通过代码为分组产品动态聚合子商品的属...
io.ReadFull返回io.ErrUnexpectedE...
本文详解Yii2中控制器向视图传递ActiveRecord数...
本文详解为何通过wp_set_object_terms()为...
Pytest中使用@mock.patch类装饰器会导致补丁泄...
带缓冲的channel是并发安全的FIFO队列;make(c...