我们都知道选择器其实就是类型里面的一个个方法,类型之间可以互相内嵌,经过代码证明,选择器会优先选择自身定义的方法,然后如果没有,就会去解析内嵌的类型的方法,例如定义类型t,同时内嵌了t1,t2两个类型,里面都有方法f,这是直接调用t.f,就会产生二义性,因为t1和t2在解析器看来都算是同一层,如果t1不变,f是在t2的内嵌t2.1定义的方法,这时候旧不会有问题,因为t1比t2高一层,但如果f同时定义在t1.t1-1和t2.t2-1的类型里面,就会报错,看出来了把,内嵌决定了方法在那一层,只要方法不在同一层,就没有二义性,类型本身为最顶层。
package main
import(
"fmt"
)
type son1 struct{
gson1
}
type gson1 struct{
}
func (gson1) f(){
fmt.Println("1")
}
type son2 struct{
gson2
}
type gson2 struct{
}
func (son2) f(){
fmt.Println("2")
}
type father struct{
son1
son2
}
func (father)f(){
}
func main(){
F := father{}
F.f()
}
可以自己拿代码去验证,实践乃第一真理