//尾随闭包:尾随闭包是一个书写着函数括号之后的闭包表达式,
//如果您需要将一个很长的闭包表达式作为最后一个参数传递给函数,可以使用尾随闭包来增强函数的可读性。
func someFunctionThatTakesAClosure(closure: () -> Void ) {
//函数体部分
}
//以下是不使用尾随闭包进行函数调用
someFunctionThatTakesAClosure ({
//闭包主体部分
})
//以下是使用尾随闭包进行函数调用
someFunctionThatTakesAClosure () {
//闭包主体部分
}
//所以上面的sort方法的排序闭包函数可以写成:
reversed = names.sort() { $0 > $1 }
//如果函数只需要闭包表达式一个参数,,当使用尾随闭包时,甚至可以把()省略掉
reversed = names.sort { $0 > $1}
//当闭包非常长以至于不能在一行中进行书写时,尾随闭包变得非常有用。
//当提供给数组的闭包应用于每个数组元素后,map方法将返回一个新的数组,数组中包含了与原数组中的元素一一对应的映射后的值。
//下面介绍了如何在map方法中使用尾随闭包将Int类型数组[16,58,510]转换为包含对应string类型的值的数组["OneSix", "FiveEight", "FiveOneZero"]
let digitNames = [
0:"Zero",1:"One",2:"Two",3:"Three",4:"Four",
5: "Five", 6: "Six", 7: "Seven", 8: "Eight", 9: "Nine"
]
let numbers = [16,58,510]
//现在可以通过传递一个尾随闭包给number的map()方法来创建对应的字符串版本数组:
let strings = numbers.map {
(var number) -> String in
var output = ""
while number > 0 {
output = digitNames[number % 10]! + output
number /= 10
}
return output
}
let num = 10
num%3
//字典下标后跟着一个叹号(  ),因为字典下标返回一个可选值(optional value),表明该键不 存在时会查找失败。在上例中,由于可以确定  总是  字典的有效下标,因此叹号可以用 于强制解包 (force-unwrap) 存储在下标的可选类型的返回值中的  类型的值。
//map为数组中每个元素调用了闭包表达式。,不需要指定闭包的输入参数number的类型,因为可以通过要映射的数组类型进行推断
//上面的例子中,通过尾随闭包语法,优雅的在函数后封装了闭包的具体功能,而不再需要将整个闭包包裹在map方法的括号内。
Swift-尾随闭包
最新推荐文章于 2024-03-29 20:59:49 发布