一、继承与重写, 防止重写
1.1 基类, 不继承任何类. Swift不想OC或者Java中继承自Object类.定义一个类,不继承任何类,该类就是基类.
-
class Person1{
-
func eat(){
-
println("eat a pig!")
-
}
-
}
1.2 继承. Swift为单继承
-
class XiaoMing1 : Person1{
-
var name = "xiaoming"
-
}
1.3 重写. 必须加关键字override. (OC,Java中是不必加的)
-
class XiaoHong1 : Person1{
-
override func eat() {
-
super.eat();
-
println("xiaohong eat a pig")
-
}
-
}
-
-
var xh = XiaoHong1()
-
xh.eat()
1.4 重写属性(存储属性与计算属性)
可以用get/set/willSet/didSet进行属性重写
可以将一个只读属性重写为一个读写属性,不可以将一个读写属性重写为一个只读属性
也就是说: 重写的范围只能是 小-->大 (类似Java)
子类重写父类的属性时, 不管父类是计算属性还是存储属性, 重写的过程就是重写其中的get/set等, 子类的override都是计算属性的格式
-
class Person2{
-
var name:String{
-
set{
-
println("Person2 set")
-
}
-
get{
-
return "Person2"
-
}
-
}
-
-
let age: Int = 10
-
-
var height:Int = 175
-
}
-
-
class XiaoMing2 : Person2{
-
override var name:String{
-
set{
-
super.name = newValue
-
println("XiaoMing2 set")
-
}
-
get{
-
return "XiaoMing2"
-
}
-
}
-
-
override var age : Int{
-
get{
-
println(super.age)
-
return 20
-
}
-
}
-
-
override var height :Int{
-
didSet{
-
println("didset----\(oldValue)")
-
}
-
willSet{
-
println("willSet----\(newValue)")
-
}
-
}
-
}
-
-
var xm2 = XiaoMing2()
-
xm2.name = "XM2"
-
println(xm2.age)
-
xm2.height = 10
1.5 防止重写(final). 与Java一样
-
-
class Person3{
-
final var name = "Person3"
-
}
-
-
class XiaoMing3{
-
-
}
二、构造器
Swift中的构造器无返回值(OC中是返回id的), 它的主要任务是保证新实例在第一次使用前完成正确的初始化工作.
init() , 可以重载
2.1 默认构造器与带参数构造器, 继承器的重载
-
class Person4{
-
var name : String
-
-
init(){
-
name = "xuneng"
-
}
-
-
-
init(name :String){
-
self.name = name + "Hello"
-
}
-
-
-
var age:Int = 10
-
init(name :String , age:Int?){
-
self.name = name
-
self.age = age!
-
}
-
-
}
-
-
var p4 = Person4()
-
var p4_1 = Person4(name: "xn4545945 ")
-
var p4_2 = Person4(name: "neng", age: 10)
2.1 指定构造器(Designated initializer)与便利构造器(convenience initializer)
2.1.1 指定构造器: 每个类必须至少有一个,用来确保所有值都进行初始化.(会根据父类的继承关系往上调用,完成父类的初始化)
2.1.2 便利构造器(加convenience关键字):辅助性的构造器.可以用来同一个类中的指定构造器,也可以用来创建一个有特定输入的实例
-
class Person5{
-
var name : String
-
-
init(name :String){
-
self.name = name + "Hello"
-
}
-
-
convenience init(name :String , height:Int){
-
self.init(name:name)
-
println(height)
-
}
-
}
-
-
var p5 = Person5(name: "xn4545945", height: 175)
2.2 构造器链(概念): 规范指定构造器与便利构造器间的调用关系.
一句话总结上面3个规律: 指定构造器是向上调用的,便利构造器是横向调用的.
2.3 两段式构造过程 (概念)
第一个阶段:每个存储型属性通过引入它们的类的构造器来设置初始值。
第二阶阶段:当每一个存储型属性值被确定后,二阶段开始,它给每个类一次机会在新实例准备使用之前进一步定制它们的存储型属性。
两段式构造过程的使用让构造过程更安全,同时在整个类层级结构中给予了每个类完全的灵活性。
Swift 的两段式构造过程跟 Objective-C中的构造过程类似。最主要的区别在于阶段一,Objective-C给每一个属性赋值 0或空值(比如说 0或 nil)。Swift的构造流程则更加灵活,它允许你设置定制的初始值,并自如应对某些属性不能以 0或 nil作为合法默 认值的情况。
2.4 构造器的继承(概念)
与OC不同, Swift中子类不会默认继承父类的构造器.
(但如果满足以下2个条件会自动继承)
1)如果子类没有定义指定构造器, 那么他将主动继承父类的
2)如果子类提供了所有父类指定构造器的实现, 那么自动继承父类的便利构造器
-
class Father{
-
init(){
-
println("father init")
-
}
-
convenience init(name:String){
-
self.init();
-
println("father convenience init")
-
}
-
}
-
-
class Son:Father{
-
override init(){
-
println("son init")
-
}
-
}
-
-
var son1 = Son()
-
var son2 = Son(name: "xuneng")
2.5 通过闭包和函数来设置属性的默认值
-
-
class SomeClass{
-
let someProperty : Int = {
-
return 0
-
}()
-
}
1)如果某个存储属性的值需要特别定制, 则可以使用闭包或全局函数类提供默认值.
2)当类型创建时, 闭包或函数会被调用,他们的返回值会被当做默认值赋值给这个存储属性.
3)使用闭包时, 实例的其他部分并没有初始化, 因而不能在闭包里面访问:其他实例属性/self属性/实例方法等.
-
class Person6{
-
let name : String = {
-
let firstName = "xu"
-
let lastName = "neng"
-
return firstName + lastName
-
}()
-
}
-
-
var p6 = Person6()
-
println(p6.name)
三、析构(反初始化) deinit
在一个类实例被释放之前, 反初始化函数被立即调用
Swift通过ARC来处理实例的内存管理, 与OC一样.
每个类只有一个反初始化函数, 不带任何参数. 且不允许主动调用.
子类继承了父类的反初始化函数(释放顺序类似Java. 先释放子类-->父类)
反初始化话方法能访问该实例的所有属性
-
class Person7{
-
var myMoney:Int
-
init(){
-
myMoney = 10
-
}
-
deinit{
-
myMoney = 0
-
-
}