闭包(即一些小的匿名代码块),可以像函数一样使用。可以很方便的将闭包传给其他函数,告诉它们应当如何执行某一个任务。
1,使用sort方法和闭包进行数组排序
sort方法返回一个数组的有序版本。(sort方法即为Swift2.0之前的sorted方法。而原来的sort方法改名为sortInPlace,用来将原数组修改成有序版本)
1
2
3
4
5
6
7
8
|
let numbers = [12,25,1,35,27] let numbersSorted = numbers. sort ({ (n1: Int , n2: Int ) -> Bool in //进行从小到大的排序 return n2 > n1 }) print (numbersSorted) //[1, 12, 25, 27, 35] |
2,闭包可以不用指定参数类型,编译器会帮我们推断的
1
2
3
4
5
6
7
8
|
let numbers = [12,25,1,35,27] let numbersSorted = numbers. sort ({ n1, n2 in //进行从小到大的排序 return n2 > n1 }) print (numbersSorted) //[1, 12, 25, 27, 35] |
3,还可以省略参数名,直接根据数字来引用每个参数($0,$1,$2......)
1
2
3
4
5
6
7
8
|
let numbers = [12,25,1,35,27] let numbersSorted = numbers. sort ({ //进行从小到大的排序 return $1 > $0 }) print (numbersSorted) //[1, 12, 25, 27, 35] |
4,如果闭包只包含一行代码,可以省略return关键字
1
2
3
4
5
6
7
8
|
let numbers = [12,25,1,35,27] let numbersSorted = numbers. sort ({ //进行从小到大的排序 $1 > $0 }) print (numbersSorted) //[1, 12, 25, 27, 35] |
5,如果一个闭包是函数调用的最后一个参数,可以将它放在括号外面。提高可读性。
1
2
3
4
5
6
7
|
let numbers = [12,25,1,35,27] let numbersSorted = numbers. sort (){ //进行从小到大的排序 $1 > $0 } print (numbersSorted) //[1, 12, 25, 27, 35] |
6,这个换行也是可选的,所以代码可再次精简
1
|
let numbersSorted = numbers. sort (){ $1 > $0 } |
7,闭包也可以存储在变量中,像调用函数一样调用它们
1
2
|
let comparator = {(a: Int , b: Int ) in a < b} comparator(2,5) //true |