登录
首页 >  Golang >  Go问答

顺序多重赋值 Go 指针和切片

来源:stackoverflow

时间:2024-03-10 13:36:26 371浏览 收藏

知识点掌握了,还需要不断练习才能熟练运用。下面golang学习网给大家带来一个Golang开发实战,手把手教大家学习《顺序多重赋值 Go 指针和切片》,在实现功能的过程中也带大家重新温习相关知识点,温故而知新,回头看看说不定又有不一样的感悟!

问题内容

我需要你帮助解决一个问题,go 文档说:

“赋值分两个阶段进行。首先,左边的索引表达式和指针间接(包括选择器中的隐式指针间接)的操作数和右边的表达式都按通常的顺序求值。其次,赋值按从左到右的顺序进行。” (赋值语句)

从上面的文本中,我可以假设指针和索引表达式应该按照标准顺序一起执行,但看起来 go 首先执行索引,然后是指针,然后是其他所有内容。

x := []int{1}
var a *[]int
a = &x

x[0], *a, x[0] = 1, []int{1, 2}, (*a)[1] 
//result: index out of range [1] with length 1 (*a)[1]

但是,我预计 *a 的新切片容量将为 2,但事实并非如此。

另一个例子是测试指针和切片的顺序:

x[0], *a, x[0] = 1, []int{1, 2}, 999 //result: [1,2]

我预计在左右顺序中,*a和x应该有一个新的切片,预期结果是[999,2]。

为了更加确定,我们可以将前面的示例修改为:

*a, x[0] = nil, 666 //result: [] - but not a panic

看起来 go 分为三个阶段

  1. 执行所有索引
  2. 执行所有指示
  3. 完成其他所有事情

我理解得对吗,指针和切片的真正顺序是什么?

提前致谢!


正确答案


从左到右,正如文档所说。

您引用了规范的正确部分来回答您的问题,但您似乎误解了所使用的语言。简单地读一下:

现在看第一个例子:

x := []int{1}
var a *[]int
a = &x

x[0], *a, x[0] = 1, []int{1, 2}, (*a)[1]

(*a)[1] 被求值时,该行上的任何赋值都尚未执行。因此,在引用的部分中出现了“第一”和“第二”一词。因此,它尝试对 []int{1}[1] 建立索引,但这是无效的。

对于第二个示例,您必须了解的是,表达式 x[0] 在计算表达式时对应于切片 x 的 0 槽。在 x[0] 求值之后,如果 x[0] 被重新分配也没关系,已经求值的 x[0] 仍然对应于原始切片的 0 槽。

第三个示例使用与第二个示例相同的知识。

您以前可能没有理解的微妙之处是索引表达式和指针间接不产生值,它们产生变量。为此,切片/数组元素也被视为变量,因此您可以将切片的基础数据想象为一系列连续存储的不同变量。因此,x[0] 的索引表达式解析为内存中的某个特定变量,该变量不再依赖于 x 的值。请记住,x 本身不是切片。 x 只是一个变量,可以表示某些切片根本没有切片,并且可以在 x 的整个生命周期中发生变化。 p>

理论要掌握,实操不能落!以上关于《顺序多重赋值 Go 指针和切片》的详细介绍,大家都掌握了吧!如果想要继续提升自己的能力,那么就来关注golang学习网公众号吧!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>