七. 闭包/Closures

闭包是独立的功能块,可以传递并在代码中使用。Swift中的关闭类似于C和Objective-C中的block以及其他编程语言中的Lambdas

1.形式:

{(参数) - >返回类型  in

声明

}

基本形式,完整
作为参数,已经能够确定该闭包的函数类型,即什么参数什么返回值,所以可以省略
因为闭包中只有一行代码,所以不会造成歧义的情况下,return可以省略
七. 闭包/Closures_第1张图片
更加简便的方式,$0,$1..这是swift提供的一些速记的编写方式
七. 闭包/Closures_第2张图片
还有更加简便的方式,不过适用条件比较特定了

2.尾闭包

七. 闭包/Closures_第3张图片
尾闭包

如果提供了一个闭包表达式作为函数或方法的唯一参数,并且您将该表达式提供为尾随闭包,则()在调用函数时,不需要在函数或方法名称后面写入一对括号

小括号都省略

尾闭包,说的就是最后一个参数是闭包,可以不用写在函数参数的小括号中,直接写在外面大括号中就行了,总之就是为了写法更加简便,意义没有什么变化

3.Capturing Values/捕捉值

七. 闭包/Closures_第4张图片
函数1里面包含另一个函数2,函数2使用了函数1的局部变量
七. 闭包/Closures_第5张图片
不断调用返回的函数2,原先的参数会不断积累

个人理解是,返回的incrementByTen是一个对象,他有保存了它的值,所以会不断的积累

4.Escaping Closures逃逸闭包

简单点介绍就是,如果这个闭包是在这个函数结束前内被调用,就是非逃逸闭包,即noescape 如果这个闭包是在函数执行完成后才被调用,调用的地方超过了这个函数的范围,就叫逃逸闭包

例如平常使用的masonry,就是非逃逸闭包,因为他是马上执行,而网络请求则是逃逸闭包,因为他是延时执行,甚至不执行

苹果官方举的例子:

七. 闭包/Closures_第6张图片
改函数结束时都没有调用该函数,只是把它加入到数组中,至于什么时候执行,不知道!
七. 闭包/Closures_第7张图片
someFunctionWithNonescapingClosure函数是立即执行闭包,所以是非逃逸闭包,还有就是逃逸闭包需要用self来引用

5.Autoclosures自动闭包

七. 闭包/Closures_第8张图片
少了个大括号
七. 闭包/Closures_第9张图片
正常的样子

你可能感兴趣的:(七. 闭包/Closures)