登录
首页 >  Golang >  Go问答

为什么无法正确将从非指针值调用的闭包添加到切片中?

来源:stackoverflow

时间:2024-03-06 11:00:29 267浏览 收藏

小伙伴们对Golang编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《为什么无法正确将从非指针值调用的闭包添加到切片中?》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

问题内容

这是 go1.12.3 linux/amd64 中的参数。

通过变量 x 向包含该函数的切片 s 添加了两个闭包。 该闭包是通过带有 t 类型的指针接收器的方法获得的。 通过变量 x 将两个闭包添加到包含函数的切片 s 中。 闭包是通过具有类型 t 的指针接收器的方法获得的。

package main

import "fmt"

type T struct {
    X int
}

func (t *T) f() func() {
    return func() { fmt.Println(t.X) }
}

func good() {
    s := []func(){}

    x := &T{1}
    s = append(s, x.f())

    x = &T{2}
    s = append(s, x.f())

    s[0]() // => 1
    s[1]() // => 2
}

func bad() {
    s := []func(){}

    x := T{1}
    s = append(s, (&x).f())  // Even if it rewrites to append(s, x.f()), the result is the same.

    x = T{2}
    s = append(s, (&x).f())

    s[0]() // => 2 WHY!?
    s[1]() // => 2
}

func main() {
    good()
    bad()
}

https://play.golang.org/p/j-818fzelqb

在上述两个函数中,good() 按预期工作。 好的 s[0]() 执行 t{1}.f()(),而 s s[1]() 执行 t{2}.f()()。 但是,bad() 运行 s[0]()s[1]() 运行 t{2}.f()()。 即使我将元素添加到切片中但没有覆盖它!

我不知道是什么导致了这种行为。 变量 x 不是具有 t 类型的值,而不是指向 t 类型值的指针吗? 还是我不知道append的调用规范?

请给我一些建议。


解决方案


因为在坏情况下,你只有一个类型为T的变量x,并且一个变量只有一个地址,因此你的切片s总是包含当您开始调用函数时,同一个函数作用于同一个变量,该变量的值为 2。

(好的情况下,您有两个类型为T的不同变量。您重用了*T类型的变量(x),但您仍然有两个不同具有不同值的T .)

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于Golang的相关知识,也可关注golang学习网公众号。

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