golang指针参数传递,实际也是值拷贝,传递的是指针所指向的内存地址。
所以,在函数内部的修改,实际是对该内存地址的修改,所以会生效。
但若在函数内部,给该指针参数重新分配一块新的内存地址,然后再对其修改,那么修改 对于函数外部而言就不会再生效了。
传递nil, 函数内初始化
type SC struct {
C string
}
func setVal(s *SC) {
s = &SC{
C: "set value",
}
}
func TestT(t *testing.T) {
var s *SC
t.Log(s)
setVal(s)
t.Log(s)
}
=== RUN TestT
test_test.go:24: <nil>
test_test.go:26: <nil>
--- PASS: TestT (0.00s)
函数内重新初始化
type SC struct {
C string
}
func setVal(s *SC) {
s = &SC{
C: "set value",
}
}
func TestT(t *testing.T) {
s := &SC{}
t.Log(s)
setVal(s)
t.Log(s)
}
=== RUN TestT
test_test.go:24: &{}
test_test.go:26: &{}
--- PASS: TestT (0.00s)
不重新赋值,只修改
type SC struct {
C string
}
func setVal(s *SC) {
s.C = "set value"
}
func TestT(t *testing.T) {
s := &SC{}
t.Log(s)
setVal(s)
t.Log(s)
}
=== RUN TestT
test_test.go:22: &{}
test_test.go:24: &{set value}
--- PASS: TestT (0.00s)
综上所述,开发过程中一定要牢记 ,对于指针参数的重新赋值一定要慎重。


