-
继承
定义一个基类
Swift中的类并不是从一个通用的基类继承而来。如果你不为你定义的类指定一个超类的话,这个类就自动成为基类。
-
重写
- 如果要重写某个特性,需要在重写定义的前面加上
override
关键字。任何缺少override
关键字的重写都会在编译时被诊断为错误。 - 在合适的地方,你可以通过使用
super
前缀来访问超类版本的方法,属性或下标。 - 如果你在重写属性中提供了
setter
,那么你也一定要提供getter
。如果你不想在重写版本中的getter
里修改继承来的属性值,你可以直接通过super.someProperty
来返回继承来的值,其中someProperty
是你要重写的属性的名字。
- 如果要重写某个特性,需要在重写定义的前面加上
-
防止重写
- 你可以通过把方法,属性或下标标记为
final
来防止它们被重写(即final var, final func, final class func,
以及final subscript
)。 - 在
class
前加final
修饰符来将整个类标记为final
的,这样的类是不可被继承的。
- 你可以通过把方法,属性或下标标记为
-
构造过程
-
存储属性的初始赋值
- 当你为存储属性设置默认值或者在构造器中为其赋值时,它们的值是被直接设置的,不会触发任何属性观察者
(property observers)
。
- 当你为存储属性设置默认值或者在构造器中为其赋值时,它们的值是被直接设置的,不会触发任何属性观察者
-
值类型的构造器代理
- 构造器可以通过调用其它构造器来完成实例的部分构造过程。这一过程称为构造器代理,它能减少多个构造器间的代码重复。
- 如果你希望默认构造器、逐一成员构造器以及你自己的自定义构造器都能用来创建实例,可以将自定义的构造器写到扩展中,而不是写在值类型的原始定义中。
-
类的继承和构造过程
- 类里面的所有存储型属性-包括所有继承自父类的属性—都必须在构造过程中设置初始值。
- 指定构造器
init(<#parameters#>) { <#statements#> }
- 便利构造器
convenience init(<#parameters#>) { <#statements#> }
- 指定构造器必须总是向上代理
- 便利构造器必须总是横向代理
- 父类的构造器仅会在安全和适当的情况下被继承。
-
可失败构造器
- 失败是指,如给构造器传入无效的参数值,或缺少某种所需的外部资源,又或是不满足某种必要的条件等。
- 语法: 在
init
关键字后面添加问号init?
。 - 可失败构造器的参数名和参数类型,不能与其它非可失败构造器的参数名,及参数类型相同。
- 带原始值的枚举类型自带一个可失败构造器
init?(rawValue:)
- 可以用非可失败构造器重写可失败构造器,但反过来不行。
-
必要构造器
- 在类的构造器前添加
required
修饰符表明所有该类的子类都必须实现该构造器。
- 在类的构造器前添加
-
析构过程
只适用于类类型。关键字
deinit
- 析构过程原理
- 在类的定义中,每个类最多只能有一个析构器,而且析构器不带任何参数。
deinit{//执行析构过程}
- 在类的定义中,每个类最多只能有一个析构器,而且析构器不带任何参数。