//尾随闭包:尾随闭包是一个书写着函数括号之后的闭包表达式,//如果您需要将一个很长的闭包表达式作为最后一个参数传递给函数,可以使用尾随闭包来增强函数的可读性。func someFunctionThatTakesAClosure(closure: () -> VoID ) { //函数体部分}//以下是不使用尾随闭包进行函数调用someFunctionThatTakesAClosure ({ //闭包主体部分})//以下是使用尾随闭包进行函数调用someFunctionThatTakesAClosure () { //闭包主体部分 }//所以上面的sort方法的排序闭包函数可以写成:reversed = names.sort() { > }//如果函数只需要闭包表达式一个参数,,当使用尾随闭包时,甚至可以把()省略掉reversed = names.sort { > }//当闭包非常长以至于不能在一行中进行书写时,尾随闭包变得非常有用。//当提供给数组的闭包应用于每个数组元素后,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 = 10num%3//字典下标后跟着一个叹号(  ),因为字典下标返回一个可选值(optional value),表明该键不 存在时会查找失败。在上例中,由于可以确定  总是  字典的有效下标,因此叹号可以用 于强制解包 (force-unwrap) 存储在下标的可选类型的返回值中的  类型的值。//map为数组中每个元素调用了闭包表达式。,不需要指定闭包的输入参数number的类型,因为可以通过要映射的数组类型进行推断//上面的例子中,通过尾随闭包语法,优雅的在函数后封装了闭包的具体功能,而不再需要将整个闭包包裹在map方法的括号内。总结
以上是内存溢出为你收集整理的Swift-尾随闭包全部内容,希望文章能够帮你解决Swift-尾随闭包所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)