Swift-尾随闭包

前端之家收集整理的这篇文章主要介绍了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方法的括号内。


猜你在找的Swift相关文章