Go不像其它面相对象语言一样可以写个class,然后在class里面写一堆方法,但是它也很巧妙的实现了这种效果,我们只需要在普通函数前面加个接受者(receiver,写在函数名前面的括号里面),这样编译器就知道这个函数(方法)属于哪个struct了。
下面是简单示例:
type A struct {
Name string
}
func (a A)foo() { //接收者写在函数名前面的括号里面
fmt.Println("foo")
}
func main() {
a := A{}
a.foo() //foo
}
需要注意的是,因为Go不支持函数重载,所以某个接收者(receiver)的某个方法只能对应一个函数,比如下面的就属于方法重复,编译无法通过:
func (a A)foo() {
fmt.Println("foo")
}
func (a A)foo(i int) {
fmt.Println(i)
}
这些可以叫做是方法绑定,接收者不仅可以是struct类型,还可以是任意自定义的其它类型,举个栗子:
type Integer int
func (integer *Integer)talk() {
fmt.Println("i am ",*integer)
}
func main() {
var i Integer = 250
i.talk() //i am 250
}
这下知道方法绑定是多么的灵活了吧
注意方法绑定只能绑定当前包里的类型
其实有两种调用方式,上面讲的那种官方管它叫method value,还有另一种调用方式,叫method expression:
type Integer int
func (integer *Integer)talk() {
fmt.Println("i am ",*integer)
}
func main() {
var i Integer = 250
(*Integer).talk(&i) //i am 250
}
最后说下访问权限,因为Go是以大小写来区分是公有还是私有,但都是针对包级别的,所以在包内所有的都能访问,而方法绑定本身只能绑定包内的类型,所以方法可以访问接收者所有成员。如果是包外调用某类型的方法,则需要看方法名是大写还是小写,大写能被包外访问,小写只能被包内访问。
有疑问加站长微信联系(非本文作者)