iOS开发Swift-闭包

1.闭包表达式语法

{ (参数) -> return 类型 in
    //内容
}
let names = ["C", "A", "E", "B", "D"]
func back(_ s1: String, s2: String) -> Bool {
    return s1 > s2   //(B > A, C > B)
}
//闭包后: var reversedNames.sorted(by: { (s1: String, s2: String) -> Bool in return s1 > s2 })

 2.根据上下文推断类型

reversedNames = names.sorted(by: {s1, s2 in return s1 > s2})
//传入参数的类型确定,: String, : String可省略。传出参数的类型确定: -> Bool可省略

3.单表达式闭包的隐式返回

reversedNames = names.sorted(by: {s1, s2 in s1 > s2})
//只包含一个表达式,省略return之后无歧义,所以可以省略return。

4.参数名称缩写

reversedNames = names.sorted(by: {$0 > $1})
//可按照$0, $1, $2顺序调用闭包函数

5.运算符方法

reversedNames = names.sorted(by: >)

6.尾随闭包

将很长的闭包表达式作为最后一个参数传递给函数,不用写出他的参数标签。

func some(do: () -> Void) {
    //代码
}
//不使用尾随闭包调用函数
some(do: {
    //代码
}
//使用尾随闭包调用函数
some() {
    //语句
}
reversedNames = names.sorted() {$0 > $1}
//sorted为函数的唯一方法时,可省略括号
reversedNames = names.sorted {$0 > $1}

7.值捕获

嵌套函数可捕获其外部函数所有参数、变量、常量。

8.逃逸闭包

当一个闭包作为一个参数传到一个函数中,但闭包在函数返回之后才被执行,则称闭包逃逸。

标注@escaping,表示允许闭包逃逸。

var comp: [() -> Void] = []
func some(comp1: @escaping () -> Void) {
    comp.append(comp1)
}

9.自动闭包

 包装传递给函数作为参数的表达式。不接受参数,只返回值。

 延迟求值。直到调用这个闭包,代码才被执行。

var cuL = ["C", "A", "E", "B", "D"]
print(cuL.count)    //5
let cuP = {cuL.remove(at: 0)}
print(cuL.count)    //5。闭包未运行
cuP()     //调用闭包
print(cuL.count)    //4。闭包已运行,第一个值被删除。