登录
首页 >  Golang >  Go问答

聊聊有关迭代时更改值的问题

来源:Golang技术栈

时间:2023-03-07 20:40:20 334浏览 收藏

今日不肯埋头,明日何以抬头!每日一句努力自己的话哈哈~哈喽,今天我将给大家带来一篇《聊聊有关迭代时更改值的问题》,主要内容是讲解golang等等,感兴趣的朋友可以收藏或者有更好的建议在评论提出,我都会认真看的!大家一起进步,一起学习!

问题内容

假设我有这些类型:

type Attribute struct {
    Key, Val string
}
type Node struct {
    Attr []Attribute
}

并且我想迭代我的节点属性以更改它们。

我很想能够做到:

for _, attr := range n.Attr {
    if attr.Key == "href" {
        attr.Val = "something"
    }
}

但由于attr不是指针,这不起作用,我必须这样做:

for i, attr := range n.Attr {
    if attr.Key == "href" {
        n.Attr[i].Val = "something"
    }
}

有没有更简单或更快的方法?是否可以直接从中获取指针range

显然我不想仅仅为了迭代而改变结构,更冗长的解决方案不是解决方案。

正确答案

不,你想要的缩写是不可能的。

这样做的原因是range从您正在迭代的切片中复制值。关于范围的规范说:

Range expression                          1st value             2nd

value (if 2nd variable is present) array or slice  a   [n]E, *[n]E, or []E   index    i  int       a[i] E

因此,范围a[i]用作数组/切片的第二个值,这实际上意味着该值被复制,使原始值不可触及。

以下代码演示了此行为:

x := make([]int, 3)

x[0], x[1], x[2] = 1, 2, 3

for i, val := range x {
    println(&x[i], "vs.", &val)
}

该代码为范围中的值和切片中的实际值打印完全不同的内存位置:

0xf84000f010 vs. 0x7f095ed0bf68
0xf84000f014 vs. 0x7f095ed0bf68
0xf84000f018 vs. 0x7f095ed0bf68

因此,您唯一能做的就是使用指针或索引,正如 jnml 和 peterSO 已经提出的那样。

以上就是《聊聊有关迭代时更改值的问题》的详细内容,更多关于golang的资料请关注golang学习网公众号!

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