1 回答

TA贡献2065条经验 获得超14个赞
这称为“鸭子类型”,它允许在需要的地方定义接口,而不是作为数据类型本身的一部分。考虑以下类型:
type X struct {...}
func (X) f()
func (X) g()
func (X) h()
该类型X具有三种方法,f(), g(), h()。如果你有一个数据结构或函数需要调用一个f()方法,你可以定义一个接口:
type FIntf interface {
f()
}
现在X实现该接口。X您可以传递需要的任何地方的实例FIntf。
如果在另一个模块中你需要g()and h(),你可以在那里定义一个接口:
type GIntf interface {
g()
h()
现在X实现GIntf.
如果您有一个没有实现您需要的接口的第三方库,这将特别有用。您可以在使用它的地方简单地定义一个接口,并使用具有正确方法集的第三方类型来实现您的接口。
这种方法的主要优点是您仍然可以模拟传统的接口概念,您可以在其中定义接口及其具体实现。最重要的是,您可以根据需要灵活地定义不同的接口,而无需修改实现。在像 Java 这样的语言中,如果您有一个获得特定接口的函数,而您的对象没有,那么即使方法集存在于原始类型上,您也必须编写一个适配器。在 Go 中,您不需要这样做。
在调用方法时,鸭子类型也允许类型安全。例如,如果您有一个必须调用方法x()及其y()参数之一的函数,请定义一个包含x()and的接口y(),并使用类型断言来验证参数是否实现了这两个方法。
- 1 回答
- 0 关注
- 175 浏览
添加回答
举报