在《Swift Programming Language》中, 描述了Swift Class实例的初始化调用有经历两个阶段。
结合下面的代码记录之。
class Person {
var name: String
var age: Int
var blog = ""
init(name: String, age: Int) {
self.name = name
self.age = age
}
}
class Programmer: Person {
var preferredSkill: String
override init(name: String, age: Int) {
self.preferredSkill = "Swift"
super.init(name: name, age: age)
self.blog = "优快云"
}
}
var programmer = Programmer(name: "Ray", age: 24)
println(programmer.preferredSkill)
第一个阶段:
1. 子类Programmer的init()方法被调用
2. Programmer类新的实例的占用内存被分配完毕,但未被初始化(allocated but not initialized)
3. Programmer类初始化由自己引入的stored property的初始值, 这些stored property的内存现在处于initialized的状态 (perferredSkill = “Swift”)
4. Programmer类调用直接父类Person类的init()方法, Person类初始化由自己引入的stored property的初始值 (name="Ray", age=24, blog="")
5. 如果Person类还有父类,重复3-4步
6. 现在新Programmer实例的所有stored property都处于initialized状态了
第二个阶段:
1. 现在可以获取并使用self属性了
2. 从Person类开始, 检查有需要改变的值么?没有, 寻找Person的直接子类Programmer类
3. 改变blog的值到“优快云” (blog = "优快云")
总结:
在构造子类的实例时,初始化方法调用分为两个阶段,第一个阶段向上初始化所有的属性,第二个阶段根据需要向下改变属性的值