以下编译和运行在运行
Swift 4的Xcode 9.2上没有问题:
class ParentWithComputedOptional { var computedOptional: Int? { return nil } } class ChildThatUnwraps: ParentWithComputedOptional { override var computedOptional: Int { return 10 } }
请注意,在父级中,computedOptional是一个Int?,但在子级中它被重写为Int.此外,必须为要编译的代码指定override关键字.这在Playground和一个合适的项目上进行了测试.
这是预期的行为吗?如果是,Apple方案文档中是否有针对此方案的相关页面?
解决方法
这种特殊的覆盖情况似乎没有在官方语言指南中的任何地方记录,但在Swift的
changelog版本中提到了4.0版本(寻找SR-1529).
本主题值得一些额外的信息:
实际上,此行为不仅限于选项,还适用于其他covariant类型,只要重写的属性是派生类中的计算只读属性即可.
例如,以下代码也将在Swift 4.1中编译.
class Animal {} class Koala: Animal {} class Foo { var x: Animal { return Animal() } } class Bar: Foo { override var x: Koala { return Koala() } }
这是一个不违反Liskov substitution principle的边缘情况,因为Base类的属性是只读的计算属性.因此,如果Bar的实例被保存在Foo类型的变量中,则无法改变其x属性,以便在将对象向下转换为Bar类型的变量时创建类型错误.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。