go 语言中可以通过匿名field来实现继承的效果,
type T1 struct {
A int
}
func (t T1) Log() {
}
func (t *T1) Print() {
}
type T2 struct {
T1
}
t2 T2{}
继承效果
可以通过t2.Log()直接访问T1的method,就像面向对象的继承之后一样访问,不过这里要注意的传递到Log的是T1而不是T2
匿名field的的名字
struct {
T1 // field name is T1
*T2 // field name is T2
P.T3 // field name is T3
*P.T4 // field name is T4
x, y int // field names are x and y
}
所以下面的声明会出现命名冲突
struct {
T // conflicts with anonymous field *T and *P.T
*T // conflicts with anonymous field T and *P.T
*P.T // conflicts with anonymous field T and *T
}
匿名field的field
匿名field的成员field和普通的field操作一样
t2 = T2{}
t2.A
唯一不同的是在初始化的时候不能这样写:
t2 = T2 {A:1}
匿名field的重名问题
- 如果相同名字
field不在统一层级,则浅层级的field隐藏深层级的field - 如果T包含匿名成员T1和T2,那么T1不能再有相同的
method或者field名字为T1或者T2 - 如果两个不同的匿名成员有相同的成员,且层级相同,比如假设T1和T2都有相同的成员C,T包含T1和T2,如果外面不访问C,则也不会出问题,但是如果外面访问了C,则编译器会报错。
关于匿名T和*T的区别
- 如果
s包含匿名T,则s和*s同时包含receiver为T的方法,*s同样包含receiver为*T的方法 - 如果
s包含匿名*T,则s和*s同时包含receiver为T和*T的方法
2315

被折叠的 条评论
为什么被折叠?



