在你的第一个例子中,你要 重写 的
description属性。因此,此实现被添加到
OddString的vtable中(因为它是一个 类
),并且可以动态地分派到正确的状态,而不管实例的静态类型是什么。
在第二个示例中,您没有类-因此没有vtables。但是,您 正在
遵守协议。协议允许通过协议见证表进行动态调度(请参阅WWDC的有关此表的详细介绍),但是这仅在协议
要求的 实现中发生。
localizedDescription不是协议的协议要求
Error,它仅在
Error您何时使用的协议扩展中定义
importFoundation(在SE-0112中进行了说明)。因此,它不能动态调度。相反,它将是静态分派的-因此调用的实现取决于实例的 静态类型 。
这就是您在此处看到的行为–将
explosive实例键入为时
TestError,将
localizedDescription调用您的实现。当键入为时
Error,将
Error调用扩展中的实现(它只是
NSError与之连接并获取
localizedDescription)。
如果要提供本地化的描述,则应
LocalizedError改用错误类型,将其定义
errorDescription为协议要求,从而可以动态分派。



