php小编西瓜为您介绍Golang中的Slice索引问题。在Golang中,Slice是一种灵活的动态数组,可以方便地对数据进行增删改查操作。但是在使用Slice时,有时候会遇到索引的问题,即索引到的值是值的拷贝还是引用。了解索引的价值和参考的区别对于正确使用Slice至关重要。接下来,我们将详细探讨这个问题,帮助您更好地理解和应用Slice。
我正在学习 go,并对我们从切片索引中得到的“东西”感到困惑。
假设我们有一个 bag
类型的结构:
type bag struct { item string }
然后,假设我们有一个行李列表:
itembag := []bag{ {item: "item1"}, {item: "item2"}, {item: "item3"} }
现在,我尝试更改 itembag
变量的第一个元素的内容。天真地,我做了以下事情:
item1 := itembag[0] item1.item = "not item1" fmt.printf("itembag[0].item == 'not item1'? %v", itembag[0].item == "not item1") // console print false
我得到的答案是错误的,因为(我想,如果我错了,请纠正我)当我们执行 item1 := itembag[0]
时,我们正在复制 itembag[0]
的值并且将其分配给 item1
。我相信这就是这个博客的含义。
为了证明这一点,我尝试获取 itembag[0]
的指针并修改其值,瞧,我实现了我想要做的事情:
item1 := &itembag[0] item1.item = "not item1" fmt.printf("itembag[0].item == 'not item1'? %v", itembag[0].item == "not item1") // console print true
如果我们说当我们进行切片索引(即 slice[index])时,我们将获得其值的副本而不是底层项目,这就很有意义了。
现在,当我执行以下操作时:
itemBag[0].item = "not item1" fmt.Printf("itemBag[0].item == 'not item1'? %v", itemBag[0].item == "not item1")
结果是true
,这不是我所期望的。 因为它看起来像 true
,这不是我所期望的。 因为它看起来像 itembag[0].item
在语法上与我首先将 itembag[0]
在语法上与我首先将 分配给变量然后引用其底层项目相同。
我觉得我错过了 golang 课程中的一个基本章节,拜托,任何重定向/解释将不胜感激!
尝试过使用谷歌搜索“通过引用传递切片索引”之类的内容,但无法在谷歌上精确定位到确切的关键字。解决方法赋值操作复制值。所以当你这样做时:
item1 = itembag[0]
itembag[0]
处创建该对象的副本,其类型为 bag
。现在 item1
您在 处创建该对象的副本,其类型为 。现在 item1
拥有它的副本,您对其所做的任何修改都将在该副本上进行。itempr
。当执行itempr.item="x"
时,相当于(*itempr).item=x
itemptr = &itembag[0]赋值的右侧是一个指针,因此此操作创建该指针的副本并将其分配给
,所以修改了指针的内容。itembag[0]
itembag[0].item
也是一个可寻址值,因此您可以为其分配一些内容,它将反映在切片本身中。
但是,以下内容不是可寻址值:m[1]
m:=map[int]bag{1:bag{item:"str"}} m[1].item="str1"这是因为
返回映射中值的副本,并且为其分配值将会丢失。但是,以下问题是可以解决的:bag
的 item
m:=map[int]*bag{1:&bag{item:"str"}} m[1].item="str1"这将在地图中设置 🎜 的
item
字段。🎜以上是Golang Slice 索引价值还是参考?的详细内容。更多信息请关注PHP中文网其他相关文章!