一个类可以继承另一个类的方法、属性和其它特性。在Swift中,继承是区分 "类" 和其它类型的基本区别。
子类可以继承父类的方法、属性和下标,也可以重写。
也可以给在类中通过继承得到的任何属性添加属性观察期,无论是存储型属性还是计算型属性。
定义一个基类(Defining a Base Class)
不继承于其它类的类就叫基类。
Swift中的类不是从一个通用的基类继承得到的。如果不为自定义的类指定一个父类的话,这个类就会自动成为基类。
Vehicle 类定义了一个通用特性的车辆类,实际上没什么用处。为了让它变得更加有用,需要完善它从而能够描述一个更加具体类型的车辆。
子类化(Subclassing)
为了指明继承于那个类,在类名后面用冒号隔开:
class SomeSubclass: SomeSuperclass {
//子类定义在这
}
重定义(Overriding)
子类可以为继承来的实例属性、方法(实例方法和类方法)和下标提供自定义的实现。这就是重定义。
如果想重定义,需要在最前面加上 override 关键字。
访问父类的方法、属性和下标
当你在子类中重写父类的方法(等)时,有事在重写版本中使用已经存在的父类实现会很有用。比如说,可以完善已有实现的方法,或在一个继承来的变量中存储一个修改过的值。
在适当的地方,可以使用 super 来访问父类的方法、属性或下标:
- 在方法 someMethod() 的重写实现中,可以通过 super.someMethod() 来调用父类的 someMethod() 方法。
- 在属性 someProperty() 的 getter 或 setter 的重写实现中,通过 super.someProperty 来访问父类的 someProperty 属性。
- 在下标的重写实现中,通过 super[someIndex] 访问父类中的相同下标。
重定义方法(Overriding Methods)
重定义属性(Overriding Properties)
重定义属性的 getter 和 setter 方法(Overriding Property Getters and Setters)
可以提供定制的 getter(setter) 来重写任意继承来的属性,无论继承来的属性是存储型的还是计算型的属性。子类并不知道继承来的属性是存储型的还是计算型的,它只知道继承来的属性会有一个名字和类型。在重定义一个属性时,必需将它的名字和类型都写出来。这样才能使编译器去检查你重写的属性是与父类中同名同类型的属性相匹配的。
可以将一个继承来的只读属性重定义为读写属性,是需要在重定义实现中提供 getter 和 setter 即可。但是不可以将父类的读写属性重定义为只读属性。
注意
如果在重定义属性中提供了 setter,那么也一定要提供 getter 方法。如果不想在重定义中修改 getter 可以直接通过 super.someProperty来返回继承来的值。
重定义属性观察期(Overriding Property Observers)
可以通过给重定义的属性为一个继承来的属性添加属性观察期,这样一来,当继承来的属性值发生改变时,就会被通知,无论那个属性原本是如何实现的。
注意
不可以为继承来的常量存储型属性或继承来的只读计算型属性添加属性观察器,所以,为它们提供 willSet 或 didSet 是不合适的。
此外,不可以同时提供重定义的 setter 和重定义的属性观察期。如果想观察属性的变化,并且已经重定义了 setter,那么直接在 setter 中就可以观察到值的变化了。
防止重定义(Preventing Overrides)
可以通过把方法,属性或下标标记为 final 防止它们被重写,只需要在声明关键字前加上 final 修饰符即可 (🌰: final var, final fun, final class func, final subscript)。
如果重写了带有final标记的方法,属性或下标,在编译时会报错。在类扩展中的方法,属性或下标也可以在扩展的定义里标记为 final 的。
可以通过在关键字 class 前添加 final 修饰符 (final class) 来将整个类标记为 final 的。这样的类是不可被继承的,试图继承这样的类会导致编译报错。