Swift学习笔记(一)
1.析构器关键字deinit
在类的定义中,每个类最多只能有一个析构器。当引用计数器为0时,实例被释放会进入该方法:
Copy
deinit {
// 执行析构过程
}
类似于OC中的-(void)dealloc方法 。在继承关系中,子类析构器实现的最后,父类的析构器也会被自动调用。
2.值类型和引用类型
结构体和枚举类型是值类型,类是引用类型。值类型存储与传递值的方式为copy一份值使用,引用类型使用引用计数器管理内存。
3.swift中的循环引用
跟OC中一样,两个实例互相强引用,会造成两个实例都无法释放内存,造成循环引用。如文档中给出的Demo:
class Person {
let name: String
init(name: String) { self.name = name }
var apartment: Apartment?
deinit { print("\(name) is being deinitialized") }
}
class Apartment {
let unit: String
init(unit: String) { self.unit = unit }
var tenant: Person?
deinit { print("Apartment \(unit) is being deinitialized") }
}
john = Person(name: "John Appleseed")
unit4A = Apartment(unit: "4A")
两个实例互相强引用:

然后将两个实例引用计数(-1):
john = nil
unit4A = nil
此时的关系如下:

可以这样理解:
- Swift中类为引用类型,引用类型的内存管理为引用方式而不是复制。
john和unit4A在实例化之后在内存中分配了一个地址存储实例化之后的对象- 当
john和unit4A置为nil之后就取消了对对应地址存储的对象引用 - 当引用计数为0时,内存中存储的对象才会自动被释放
- 此时内存中的两个对象还在互相强引用,所以不该段内存不会释放。
3.解决循环引用
无主引用(Unowned References)和弱引用