Go中交换变量值必须用指针:函数参数为int,调用时传&x、&y,函数内用a, b = b, *a并行赋值;值传递无法修改原变量,因Go所有参数均为值传递。
Go 语言中不能直接通过函数参数修改原始变量值,必须传入指针。常见错误是只传值、没解引用,导致交换失败。
关键点:函数参数类型必须是 *int(或其他对应类型的指针),并在函数体内用 *a 和 *b 显式解引用赋值。
&x 和 &y 获取地址*a = *b 这类语法操作实际内存位置swap(&x, &y) 简写宏,必须显式写交换逻辑func swap(a, b *int) {
*a, *b = *b, *a // Go 支持并行赋值,安全且简洁
}
x, y := 10, 20
swap(&x, &y)
// 此时 x == 20, y == 10
Go 所有参数都是值传递,包括指针本身——但指针的“值”是地址。如果函数签名是 func swap(a, b int),那函数内部只是在操作副本,对调用方的 x、y 完全无影响。
典型误判现象:swap(x, y) 调用后打印 x、y 发现没变,就是掉进了值传递陷阱。
int&),只有指针类型若需交换任意可比较类型(int、stri、自定义结构体等),可用泛型避免重复写多个指针版本。
ng
注意:泛型函数仍需指针参数,否则无法修改原值;类型约束建议用 comparable,除非你明确需要支持不可比较类型(此时需用 any 并承担运行时风险)。
func Swap[T comparable](a, b *T) {
*a, *b = *b, *a
}
s1, s2 := "hello", "world"
Swap(&s1, &s2) // s1 == "world", s2 == "hello"
指针交换本身简单,但实际使用中常因空指针或生命周期问题崩溃。
nil 指针会导致 panic: invalid memory address or nil pointer dereference
map 中的值直接取地址)sync.Mutex 或 atomic 包最常被跳过的其实是空指针检查——哪怕业务逻辑里“不可能为 nil”,上线后某个初始化漏掉就直接 crash。