自学Swift --> 闭包

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,目前对我来说用不到!我是一个懒人!

不足之处,请直接留言,我目标是做一个分享的人。大家多交流!

你可能感兴趣的:(自学Swift --> 闭包)