登录
首页 >  Golang >  Go问答

Golang重用从切片复制内存地址?

来源:Golang技术栈

时间:2023-04-15 11:22:25 235浏览 收藏

本篇文章向大家介绍《Golang重用从切片复制内存地址?》,主要包括golang,具有一定的参考价值,需要的朋友可以参考一下。

问题内容

我在我正在处理的项目中遇到了一个问题。我找到了解决方法,但我不确定为什么我的解决方案有效。我希望有人对 Go 指针的工作方式有更多经验可以帮助我。

我有一个 Model 接口和一个实现该接口的 Region 结构。Model 接口是在 Region 结构的指针上实现的。我还有一个 Regions 集合,它是 Region 对象的一部分。我有一个可以将 Regions 对象转换为 []Model 的方法:

// Regions is the collection of the Region model
type Regions []Region

// Returns the model collection as a list of models
func (coll *Regions) ToModelList() []Model {
    output := make([]Model, len(*coll))
    for idx, item := range *coll {
        output[idx] = &item
    }
    return output
}

当我运行这段代码时,我最终得到了多次输出的区域的第一个指针。所以,如果 Regions 集合有两个不同的项目,我会得到相同的地址重复两次。当我在切片中设置变量之前打印变量时,它们具有正确的数据。

我有点搞砸了,认为 Go 可能会在循环之间重用内存地址。该解决方案目前在我的测试中为我工作:

// Returns the model collection as a list of models
func (coll *Regions) ToModelList() []Model {
    output := make([]Model, len(*coll))
    for idx, _ := range *coll {
        i := (*coll)[idx]
        output[idx] = &i
    }
    return output
}

这给出了输出切片中两个不同地址的预期输出。

老实说,这似乎是 range 函数在运行之间重用相同内存地址的错误,但我总是认为在这种情况下我会丢失一些东西。

我希望我已经为你解释得足够好。我很惊讶原来的解决方案不起作用。

谢谢!

正确答案

在您的第一个(非工作)示例item中是循环变量。它的地址不变,只有它的值。idx这就是为什么您在输出时间获得相同地址的原因。

运行此代码以查看运行中的机制;

func main() {

    coll := []int{5, 10, 15}

    for i, v := range coll {
       fmt.Printf("This one is always the same; %v\n", &v)
       fmt.Println("This one is 4 bytes larger each iteration; %v\n", &coll[i])
    }
}

文中关于golang的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Golang重用从切片复制内存地址?》文章吧,也可关注golang学习网公众号了解相关技术文章。

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