在《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 = "CSDN" } } 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的值到“CSDN” (blog = "CSDN")
总结:
在构造子类的实例时,初始化方法调用分为两个阶段,第一个阶段向上初始化所有的属性,第二个阶段根据需要向下改变属性的值
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。