当前位置: > > > > Go如何将方法绑定到对象?
来源:stackoverflow
2024-04-24 20:45:35
0浏览
收藏
Golang不知道大家是否熟悉?今天我将给大家介绍《Go如何将方法绑定到对象?》,这篇文章主要会讲到等等知识点,如果你在看完本篇文章后,有更好的建议或者发现哪里有问题,希望大家都能积极评论指出,谢谢!希望我们能一起加油进步!
问题内容
我几天前刚刚开始学习 go。今天,我们在调试一段代码一段时间时,发现了一些看起来与 go 违反直觉的事情。
首先我们定义了一个接口和一个实现它的数据结构。
type executer interface { execute() } type whatever struct { name string } func (this *whatever) execute() { log.println(this.name) }
现在考虑我有一个指向 whatever
的 nil 指针,并且我尝试调用方法 execute
。在我到目前为止使用的其他面向对象语言中,这会在调用方法(即 w.execute()
)时调用空指针错误,因为对象指针为空。有趣的是,在go中,调用该方法时,当我尝试取消引用this.name
时,在execute
方法处发生空指针错误。为什么不在调用方法时呢?
func main() { var w *whatever w.Execute() }
所以,我现在想了解的是这怎么可能?这是否意味着 go 只在编译时进行早期方法绑定,而在运行时没有方法与特定对象的绑定?
解决方案
接收者只是函数的“普通”参数。普通参数可以是指针类型。那时,您可以传递 nil
作为参数,这是完全有效的。您需要记住的只是不要取消引用 nil
指针参数。这同样适用于特殊接收器参数。如果它是一个指针,则可能是 nil
,只是不能取消引用它。
接收者是通过方法名称前面的额外参数部分指定的。
…据说该方法绑定到其接收者基本类型,并且方法名称仅在 t
或 *t
类型的 范围内可见。
允许 nil
接收器值不仅仅是不被禁止的事情,它还有实际用途。有关示例,请参阅 。
在 java 中,您也可以对 null
对象调用静态方法。确实,你不能在 go 中做同样的事情,因为 go 没有像 static
、public
、private
等修饰符。在 go 中只有导出和非导出方法(由其名称的第一个后者暗示)。 p>
但是 go 也提供了类似的东西: 和 。如果您有一个带有 t
接收器类型的方法 m
,则表达式 t.m
将是一个函数值,其签名包含 m
的参数和结果类型,并带有“前缀”接收器类型。
例如:
type foo int func (f foo) bar(s string) string { return fmt.sprint(s, f) } func main() { foobar := foo.bar // a function of type: func(foo, string) string res := foobar(1, "go") fmt.println(res) }
foo.bar
将是一个类型为 func (foo, string) string
的函数,您可以像任何其他普通函数一样调用它;并且您还必须将接收者作为第一个参数传递。上述应用程序输出(在 上尝试):
go1
稍微“向前”一点,我们不需要将 foo.bar
存储在变量中,我们可以直接调用 foo.bar
:
fmt.println(foo.bar(1, "go"))
输出相同(在 上尝试)。现在,这几乎看起来像 java 中的 static
方法调用。
作为“最后”步骤,当我们对 foo
本身的值(而不是类型标识符)使用上述表达式时,我们会得到方法值,这会保存接收者以及方法值的类型不包含接收者,它的签名将是方法的签名,我们可以调用它而无需传递接收者:
var f Foo = Foo(1) bar := f.Bar fmt.Println(bar("Go"))
这将再次输出相同的内容,请在 上尝试。
查看相关问题:
文中关于的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《Go如何将方法绑定到对象?》文章吧,也可关注公众号了解相关技术文章。