在学习指针时遇到一个问题,在网上贴出后,得到很多前辈的指导和耐心解答,在此表示感谢,因此整理了此篇文章。
第一次实验,代码如下:
type Student struct {
Name string
}
func remove(stu *Student) {
fmt.Printf("2----%v\n", stu)
stu = nil
fmt.Printf("3----%v\n", stu)
}
func main() {
stu := &Student{"中国"}
fmt.Printf("1----%v\n", stu)
remove(stu)
fmt.Printf("4----%v\n", stu)
}
自己开始的理解是,因为remove传入的是指针,stu=nil,就可以将main中的stu置为空,但实际执行结果如下:
1---- &{中国}
2---- &{中国}
3---- <nil>
4---- &{中国}
第二次实验,代码如下:
func remove(stu *Student) {
fmt.Printf("2----%p\n", stu)
stu = nil
fmt.Printf("3----%p\n", stu)
}
func main() {
stu := &Student{"中国"}
fmt.Printf("1----%p\n", stu)
remove(stu)
fmt.Printf("4----%p\n", stu)
}
将指针内容打印出来,执行如果如下:
1----0xc0420321d0
2----0xc0420321d0
3----0x0
4----0xc0420321d0
发现指针内容都是一样的,第三步将指针内容置为nil,但第四步指针内容还是不变。
第三次实验,代码如下:
func remove(stu *Student) {
fmt.Printf("2----%v\n", &stu)
stu = nil
fmt.Printf("3----%v\n", &stu)
}
func main() {
stu := &Student{"中国"}
fmt.Printf("1----%v\n", &stu)
remove(stu)
fmt.Printf("4----%v\n", &stu)
}
将指针内容打印出来,如果如下:
1----0xc04206a018
2----0xc04206a028
3----0xc04206a028
4----0xc04206a018
到此为止,才终于找到原因,总结如下:
Go语言中当函数参数为指针时,同样是值传递。(什么叫值传递:值传递是指在调用函数时将实际参数复制一份传递到函数中,这样在函数中如果对参数进行修改,将不会影响到实际参数)
当函数参数为指针时,是将指针复制一份附本给函数中,所以上面例子中main与remove中的两个指针是不同的地址(见第三次实验,指针的指针),但他们都指向同一个Student对象,所以指针里存储的地址是相同的(见第二次实验)。
fmt.Printf中%p是打印指针里存储的地址,不是指印指针本身所在的地址。
Go语言中地址传递及指针的理解
main与remove中是不同的两个指针,当我们在remove中调用stu=nil时,只是改变了remove中指针存储的内容,对main中的指针是没有影响的。
©著作权归作者所有:来自51CTO博客作者thao888的原创作品,如需转载,请注明出处,否则将追究法律责任
共同学习,写下你的评论
评论加载中...
作者其他优质文章