前端之家收集整理的这篇文章主要介绍了
Swift-尾随闭包,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
//尾随闭包:尾随闭包是一个书写着函数括号之后的闭包表达式,
//如果您需要将一个很长的闭包表达式作为最后一个参数传递给函数,可以使用尾随闭包来增强函数的可读性。
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,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方法的括号内。
原文链接:https://www.f2er.com/swift/324754.html