2 回答
TA贡献1804条经验 获得超8个赞
Go 使用接口来泛化类型。因此,如果您想要一个采用特定接口的函数,您可以编写
func MyFunction(t SomeInterface) {...}
每个满足的类型SomeInterface都可以传递给MyFunction.
现在,SomeInterface看起来像这样:
type SomeInterface interface {
SomeFunction()
}
为了满足SomeInterface,实现它的类型必须实现SomeFunction()。
但是,如果您需要一个空接口 ( interface{}),则该对象不需要实现任何传递给函数的方法:
func MyFunction(t interface{}) { ... }
上面的这个函数将采用每种类型,因为所有类型都实现了空接口。
取回类型
现在您可以拥有所有可能的类型,问题是如何取回之前实际放入的类型。空接口不提供任何方法,因此您不能对这样的值调用任何东西。
为此,您需要类型断言:让运行时检查值 Y 中是否存在类型 X,如果是,则将其转换为该类型。
例子:
func MyFunction(t interface{}) {
v, ok := t.(SomeConcreteType)
// ...
}
在这个例子中,输入参数t被断言为类型SomeConcreteType。如果t 实际上是 type SomeConcreteType,v则将持有该类型的实例并且ok为真。否则,ok将是假的。有关详细信息,请参阅类型断言的规范。
TA贡献1806条经验 获得超8个赞
一个interface
变量可以保存任何类型的值,这些值为方法提供了来自接口声明的签名。由于interface{}
没有指定任何方法,这样的变量可以存储任何类型的值。
然后该方法继续使用类型断言来检查它other
实际上是一个*ContactRecord
值(否则它会恐慌)。
然后您可能会问为什么不将方法声明为带*ContactRecord
参数。最可能的原因是该*ContactRecord
类型使用Less
具有该签名的方法实现了某个接口。
- 2 回答
- 0 关注
- 499 浏览
添加回答
举报