一、示例
由于闭包本质上也是引用类型,因此也可能在闭包和上下文捕获变量(或常量)之间出现强引用类型,并不是所有的捕获变量或常量都会发生强引用循环问题,只有将一个闭包赋值给对象的某个属性,并且这个闭包体使用了该对象,才会产生闭包强引用循环
class Employee {
var no:Int
var firstName:String
var lastName:String
var job:String
var salary:Double
init(no:Int,firstName:String,lastName:String,job:String,salary:Double){
self.no = no
self.firstName = name
self.lastName = name
self.job = job
self.salary = salary
println("员工\(firstName)已经构造成功")
}
deinit{
println("员工\(firstName)已经析构成功")
}
lazy var fullName:()->String = {
return self.firstName + "." + self.lastName
}
}
var emp:Employee? = Employee(no:10,firstName:"tom",lastName:"chen",job:"IT",salary:1000.0)
println(emp!.fullName())
emp = nil
二、解决闭包中的强引用循环
解决闭包强引用循环问题有2种方法:弱引用和无主引用,到底应该采用弱引用还是无主引用,与2个对象之间的选择条件是一样的,如果闭包和捕获的对象总是互相引用和同时销毁,即将闭包内的声明为无主引用,当捕获的对象有时可能为nil时,即将闭包内的捕获声明为弱引用,如果捕获的对象绝对不会为nil时,那么应该采用无主引用
1、普通的格式
lazy var 闭包:<闭包参数列表>-><闭包返回值>={
[unowned捕获对象]<闭包参数列表>-><返回值类型> in
或[weak 捕获对象]<闭包参数列表>-><返回值类型> in
}
示例
lazy var fullName:()->String = {
[weak self](firstName:String,lastName:String)->String in
//闭包体
}
2、缩写格式
lazy var 闭包:<闭包参数列表>-><闭包返回值>={
[unowned捕获对象] in
或[weak 捕获对象] in
//闭包体
}
示例
lazy var fullName:()->String = {
[weak self] in
//闭包体
}
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。