Swift协议继承同名协议方法
在阅读有关异常的 swift 论坛时,我发现了一个有趣的问题。关于异常的例子之一是这样的:
protocol Base {
func foo() throws -> Int
}
protocol Refined: Base {
func foo() -> Int
}
struct Test: Refined {
func foo() -> Int {
0
}
}
有趣的是,我认为它不会编译是错字,但它确实如此。我不确定这在幕后是如何工作的。我的意思是当协议采用另一个协议时,它也采用了它的要求。但在这种情况下,声明相同的方法而不抛出某种方式也满足第一个协议Base。
至少我预计Test需要有 2 个foo. 我在这里缺少什么?
回答
这是因为根据定义,非抛出函数是抛出函数的子类型
来自 Swift Programming Language 一书
throws 关键字是函数类型的一部分,非抛出函数是抛出函数的子类型。因此,您可以在与抛出函数相同的位置使用非抛出函数。
但是你不能反过来做,所以下面的代码会产生一个错误
protocol Base {
func foo() -> Int
}
protocol Refined: Base {
func foo() throws -> Int //error: Cannot override non-throwing method with throwing method
}
另请注意,这不仅适用于协议,如果从中删除 func 声明,Refined您仍然可以将函数实现Test为非抛出。