Go语言中地址传递及指针的理解

释放双眼,带上耳机,听听看~!

在学习指针时遇到一个问题,在网上贴出后,得到很多前辈的指导和耐心解答,在此表示感谢,因此整理了此篇文章。

第一次实验,代码如下

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----0xc0420321d02----0xc0420321d03----0x04----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----0xc04206a0182----0xc04206a0283----0xc04206a0284----0xc04206a018

到此为止,才终于找到原因,总结如下:

  • Go语言中当函数参数为指针时,同样是值传递。(什么叫值传递:值传递是指在调用函数时将实际参数复制一份传递到函数中,这样在函数中如果对参数进行修改,将不会影响到实际参数)

  • 当函数参数为指针时,是将指针复制一份附本给函数中,所以上面例子中main与remove中的两个指针是不同的地址(见第三次实验,指针的指针),但他们都指向同一个Student对象,所以指针里存储的地址是相同的(见第二次实验)。

  • fmt.Printf中%p是打印指针里存储的地址,不是指印指针本身所在的地址。

  • main与remove中是不同的两个指针,当我们在remove中调用stu=nil时,只是改变了remove中指针存储的内容,对main中的指针是没有影响的。

【转自慕课】https://www.imooc.com

Go

RN实战项目网络请求封装

2022-3-3 17:04:45

Go

Golang 数组与分片

2022-3-3 17:08:25

搜索