type tester interface {
test()
string() string
}
type data struct{}
func (*data) test(){}
func (data) string() string {return “”}
编辑器根据方法集合来判断是否实现了接口,显然在上列中只有*data 才符合 tester 要求
这是为啥?
type tester interface {
test()
string() string
}
type data struct{}
func (*data) test(){}
func (data) string() string {return “”}
编辑器根据方法集合来判断是否实现了接口,显然在上列中只有*data 才符合 tester 要求
这是为啥?
在Go语言中,接口的实现是基于方法集的概念。一个类型要实现一个接口,必须满足该接口的方法集合,也就是接口中定义的所有方法。
在给定的示例中,接口tester定义了两个方法:test()和string() string。而类型data定义了 func (*data) test()和func (data) string() string两个方法。
根据Go语言的规范,对于一个类型来说,只有指针接收者的方法会被包含在该类型的方法集中,而值接收者的方法不会被包含在该类型的方法集中。
因此,在示例中,data类型的方法集包含了tester接口的所有方法,因为data类型实现了test()和string() string两个方法。而data类型的方法集只包含了string() string方法,没有实现tester接口的test()方法。
这也意味着只有使用指针类型的变量才能被赋值给tester接口类型的变量,如下所示:
var t tester
d := data{}
t = &d // 可以赋值,因为 *data 类型实现了 tester 接口的所有方法
而如果使用值类型的变量,则无法赋值给tester接口类型的变量,会编译报错:
var t tester
d := data{}
t = d // 编译报错,因为 data 类型没有实现 tester 接口的 test() 方法
这种设计是为了确保在使用接口时能够正确调用到实现的方法,避免可能的错误。因此,在判断一个类型是否实现了接口时,需要根据方法集的规则进行判断,只有方法集包含了接口的所有方法,才能认为该类型实现了接口。