返回顶部
首页 > 资讯 > 精选 >如何确定作为函数参数传递的指针是否正在被修改,或者副本是否正在被修改?
  • 850
分享到

如何确定作为函数参数传递的指针是否正在被修改,或者副本是否正在被修改?

2024-02-06 09:02:06 850人浏览 八月长安
摘要

问题内容 package main import ( "fmt" ) type Numbers struct { x int y int } func i

问题内容

package main

import (
    "fmt"
)

type Numbers struct {
    x int
    y int
}

func initial(number *Numbers) {
    number.x = 1
    number.y = 1
}

func final(number *Numbers) {
    number = &Numbers{2, 2}
}

func main() {
    p := Numbers{0, 0}
    fmt.Println(p) //Prints {0 0}

    initial(&p)
    fmt.Println(p) //Prints {1 1}

    final(&p)
    fmt.Println(p) //Expected to print {2, 2} but prints {1, 1}
}

为什么 initial 函数修改指针,而 final 函数修改指针的副本?

initialfinal的函数参数都指向pmain中的内存地址; initial 能够更改 p,而 final 则不能。

任何解释为什么会出现这种情况,我们将不胜感激。


正确答案


要修改指针指向的数据,必须取消引用该指针。解引用运算符是 *。然而,为了方便使用,Go 在某些情况下会隐式插入解引用操作。例如,number.x = 1 被转换为 (*number).x = 1

这种隐式翻译可能会令人困惑,但您应该看到,如果翻译没有发生,那么表达式 number.x = 1 将毫无意义,因为 number 是指针类型,并且指针没有字段。

综上所述,initial 函数具有隐式指针解引用,而 final 则没有。

如果您将 final 更改为显式且正确地取消引用,*number = Numbers{2, 2},那么它也会更改 p

以上就是如何确定作为函数参数传递的指针是否正在被修改,或者副本是否正在被修改?的详细内容,更多请关注编程网其它相关文章!

--结束END--

本文标题: 如何确定作为函数参数传递的指针是否正在被修改,或者副本是否正在被修改?

本文链接: https://lsjlt.com/news/561406.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作