the*_*ory 2 field function accessor go
鉴于这个简短的计划:
package main
import "fmt"
type Foo struct {
doer func()
}
func (f Foo) SetDoer(doer func()) {
f.doer = doer
}
func main() {
foo := Foo{func() { fmt.Println("original") }}
foo.doer()
foo.SetDoer(func() { fmt.Println("replacement") })
foo.doer()
}
Run Code Online (Sandbox Code Playgroud)
输出是:
original
original
Run Code Online (Sandbox Code Playgroud)
我原以为是:
original
replacement
Run Code Online (Sandbox Code Playgroud)
为什么不呢?请注意,如果我foo.doer直接设置,输出是预期的main().如果我使用这种SetDoer方法就不行.
在Go中,函数名左侧的项是接收类型.这是可以调用函数的类型.但是,接收器既可以是指针,也可以是值类型.在这种情况下,它是一个值.接收器纯粹是为了组织的目的,在封面下,它像任何其他参数一样传递给函数.您正在传递值,因此foo传入一个副本,SetDoer修改该值,然后设置器返回,该值超出范围,并且在调用范围内您正在使用原始值.
试试这个;
// make the receiver a pointer
func (f *Foo) SetDoer(doer func()) {
f.doer = doer
}
// instantiate as pointer
foo := &Foo{func() { fmt.Println("original") }}
foo.SetDoer(func() { fmt.Println("replacement") })
// now the version of doer on foo has been updated.
Run Code Online (Sandbox Code Playgroud)
游乐场示例; https://play.golang.org/p/ZQlvKiluu3
| 归档时间: |
|
| 查看次数: |
52 次 |
| 最近记录: |