Go语言选择器是如何选择的

我们都知道选择器其实就是类型里面的一个个方法,类型之间可以互相内嵌,经过代码证明,选择器会优先选择自身定义的方法,然后如果没有,就会去解析内嵌的类型的方法,例如定义类型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()
}

可以自己拿代码去验证,实践乃第一真理

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值