我有一个结构体
type keeper struct {
ptr int32
}然后我给它添加了一个函数
func(l keeper) next() {
l.ptr++
}但是当我创建一个新的keeper并调用next()
tester := keeper {
ptr: 0,
}
test.next()似乎我没有在tester中修改PTR值。如果我将函数更改为指针,它就能正常工作
func(l *keeper) next() {
l.ptr++
}为什么会这样呢?
发布于 2017-06-29 23:28:19
在Go中,方法只是一个接收类型实例的函数。如果您的函数接收一个实例作为值,则该值本质上是该实例的副本,该副本将是您的函数的本地实例,并且您对该实例所做的任何更改都不会应用于原始实例。如果您的函数接收到一个指向实例的指针,则您所做的任何更改都将直接在原始实例上完成。
https://stackoverflow.com/questions/44828738
复制相似问题