Swift閉包

let arr = ["alex","tony","bob"]

內(nèi)聯(lián)閉包

let arr0 = arr.sorted(by: { (s1:String,s2:String) -> Bool in
    return s1 < s2
})
print("arr0 = ",arr0)       
//打印結(jié)果:arr0 =  ["alex", "bob", "tony"]

根據(jù)上下文推斷類型 省略()、->、Bool,寫成單行表達(dá)式:

let arr1 = arr.sorted(by: {s1,s2 in return s1 > s2})
print("arr1 = ",arr1)
//打印結(jié)果:arr1 =  ["tony", "bob", "alex"]

單行表達(dá)式省略return:

let arr2 = arr.sorted(by: {s1,s2 in s1 < s2})
print("arr2 = ",arr2)
//打印結(jié)果:arr2 =  ["alex", "bob", "tony"]

參數(shù)名稱縮寫:

let arr3 = arr.sorted(by: {$0 > $1})
print("arr3 = ",arr3)
//打印結(jié)果:arr3 =  ["tony", "bob", "alex"]

運(yùn)算符方法:

let arr4 = arr.sorted(by: <)
print("arr4 = ",arr4)
//打印結(jié)果:arr4 =  ["alex", "bob", "tony"]

尾隨閉包

尾隨閉包是一個(gè)書寫在函數(shù)括號(hào)之后的閉包表達(dá)式,函數(shù)支持將其作為最后一個(gè)參數(shù)調(diào)用,在使用尾隨閉包時(shí),你不用寫出他的參數(shù)標(biāo)簽。

let arr5 = arr.sorted { (s1, s2) -> Bool in
    s1 > s2
}
print("arr5 = ",arr5)
//打印結(jié)果:arr5 =  ["tony", "bob", "alex"]

尾隨閉包改寫:

let arr6 = arr.sorted() {
    $0 < $1
}
print("arr6 = ",arr6)
//打印結(jié)果:arr6 =  ["alex", "bob", "tony"]

如果閉包是函數(shù)或者方法的唯一參數(shù),則可以把()省略:

let arr7 = arr.sorted {
    $0 > $1
}
print("arr7 = ",arr7)
//打印結(jié)果:arr7 =  ["tony", "bob", "alex"]

捕獲值

func makeIncrement(_ increment:Int) -> () -> Int {
    var runningTotal = 0
    func incrementer() -> Int {
        runningTotal += increment
        print(runningTotal)
        return runningTotal
    }
    return incrementer
}
let incrementByTen = makeIncrement(10)
incrementByTen()        //返回的值為10
incrementByTen()        //返回的值為20
incrementByTen()        //返回的值為30

閉包是引用類型:

let alsoIncrementByTen = incrementByTen
alsoIncrementByTen()        //返回的值為40

逃逸閉包

當(dāng)一個(gè)閉包作為參數(shù)傳到一個(gè)函數(shù)中,但是這個(gè)閉包在函數(shù)返回之后才被執(zhí)行,稱為該閉包從函數(shù)“逃逸”。當(dāng)你定義接受閉包作為參數(shù)的函數(shù)時(shí),你可以在參數(shù)名之前標(biāo)注@escaping,用來(lái)指明這個(gè)閉包是允許“逃逸”出這個(gè)函數(shù)的。例如:

var completionHandlers : [() -> Void] = []
func someFunc(completionHandler:@escaping () -> Void) {
    completionHandlers.append(completionHandler)
}
func funcA() {
    print("abc")
}
someFunc(completionHandler: funcA)        //此時(shí)funcA還未執(zhí)行
completionHandlers.first?()               //打印"abc"
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 閉包是自包含的函數(shù)代碼塊,可以在代碼中被傳遞和使用。Swift 中的閉包與 C 和 Objective-C 中的代...
    窮人家的孩紙閱讀 1,811評(píng)論 1 5
  • 閉包是功能性自包含模塊,可以在代碼中被傳遞和使用。Swift中的閉包與 C 和 Objective-C中的 blo...
    AirZilong閱讀 387評(píng)論 0 2
  • 閉包是自包含的函數(shù)代碼塊,可以在代碼中被傳遞和使用。Swift 中的閉包與 C 和 Objective-C 中的代...
    小驢拉磨閱讀 346評(píng)論 0 0
  • 感覺有點(diǎn)難懂,可以參考http://www.itdecent.cn/p/49e7a29a2698 閉包是自包含的...
    CDLOG閱讀 700評(píng)論 0 0
  • 閉包表達(dá)式語(yǔ)法有如下的一般形式: 閉包表達(dá)式參數(shù) 可以是 in-out 參數(shù),但不能設(shè)定默認(rèn)值。也可以使用具名的可...
    huiyuM閱讀 314評(píng)論 0 1

友情鏈接更多精彩內(nèi)容