4月份换的工作,以前都是OC开发APP,新公司采用的是Swift,所以为了更好的工作,目前处于边做边学的阶段, 写这些就是为了记录一下学习过程。
ps:目前大环境还是以Swift为主,除非是那些特别老的项目! 但是也逐步进行混编开发了。
闭包的定义
Swift开发文档中定义是:闭包是可以在代码中被传递跟引用的功能性独立模块。
具体理解这句话就是,闭包是一个包含函数,函数指针,以及可以声明上下文的模块,函数负责功能,函数指针,只想函数,声明上下文,例如捕获变量等
其实闭包是计算机中一种概念,具体就是闭包是由函数与相关引用环境组合而成的实体。这句话就可以看出,闭包不仅仅是对Swift语言,对其他语言也有同样的定义。
由此可以得出,其实oc 中的block是对闭包的具体实现。Swift中其实也是同样的道理,
具体使用:回调,遍历,并发任务等。
特性:自动捕获上下文、独立代码块、需要时运行、作为函数传递、可以有返回值、单独实现
注意:循环引用,已经多线程环境下防止weakself被析构,需要strong一下。
闭包的具体实现,百度一下就能有很多,需要用的时候自己的查找,需要注意的是
1、尾随闭包
就是再函数尾部添加一个闭包,函数支持将其作为一个参数调用。简而言之就是在函数的返回之前调用。
2、逃逸闭包
是在函数返回之后再去调用,例如我们封装支付功能时候,获取回调结果,我们通常会定义一个resultBlock的闭包用来返回支付状态,此时我们是先调用了支付功能的函数,需要在支付函数调用完成后才能知道支付结果。此时我们用的就是逃逸闭包,简而言之,就是在函数调用返回后才去执行的闭包就是逃逸闭包。
3、循环引用
循环引用产生的原因就两个对象之间的相互引用,导致两个持有一直存在,无法释放,就形成了循环引用。
一个简单的例子:
typealias resulstBlock = () ->Void
class A:NSObject{
var result =resulstBlock?
self.result{
self.dosometing()
}
func dosometing(){
print("1243546")
}
}
此时A类有一个resulstBlock闭包类型的属性,在这个闭包实现中又包含A类自己,就形成了循环引用。
解决思路:打破循环闭环
解决方式:
ARC中, 使用weakself ,将A类在闭包中调用的时候改为弱引用,当对象销毁后,自动设置为nil。
Swift中还是weakself这种方式最好。其他的没有去研究,例如unowned,目前对我来说用不到!我是一个懒人!
不足之处,请直接留言,我目标是做一个分享的人。大家多交流!