《從零開始學Swift》學習筆記(Day 22)——閉包那些事兒!

智捷關東昇發表於2016-03-15

原創文章,歡迎轉載。轉載請註明:關東昇的部落格

  我給Swift 中的閉包一個定義:閉包是自包含的匿名函式程式碼塊,可以作為表示式、函式引數和函式返回值,閉包表示式的運算結果是一種函式型別。
  Swift中的閉包類似於Objective-C 中的程式碼塊、Java中的匿名內部類。
使用閉包表示式
  Swift中的閉包表示式很靈活,其標準語法格式如下:
    { (引數列表) ->返回值型別 in
      語句組
    }
  其中,引數列表與函式中的引數列表形式一樣,返回值型別類似於函式中的返回值型別,但不同的是後面有in關鍵字。
  Swift提供了多種閉包簡化寫法,我來介紹下面幾種不同形式:
1、型別推斷簡化
  型別推斷是Swift的強項,Swift可以根據上下文環境推斷出引數型別和返回值型別。以下程式碼是標準形式的閉包:

{(a:Int, b:Int) -> Int in
    return a + b
}

Swift能推斷出引數a和b是Int型別,返回值也是Int型別。簡化形式如下:

{(a, b) in return a + b }    
{a, b in return a + b }    //引數列表括號也可以省略

2、隱藏return關鍵字
  在閉包內部語句組只有一條語句,如return a + b等,那麼這種語句都是返回語句。前面的關鍵字return可以省略,省略形式如下:
  使用這種簡化方式修改後的示例程式碼如下:

func calculate(opr :String)-> (Int,Int)-> Int {
    var result : (Int,Int)-> Int

    switch (opr) {
    case "+" :
    result = {a, b in a + b } //return關鍵字省略了
    default:
    result = {a, b in a - b } //return關鍵字省略了
    }
    return result

}

  省略的前提是閉包中只有一條return語句。
3、省略引數名稱
  Swift提供了引數名省略功能,我們可以用$0、$1、$2…來指定閉包中引數,$0指代第一個引數,$1指代第二個引數,$2指代第三個引數,以此類推$n+1指代第n個引數。
  使用引數名省略功能,在閉包中必須省略引數列表定義,Swift能夠推斷出這些縮寫引數的型別。引數列表省略了,in關鍵字也需要省略。引數名省略之後如下所示:
    {$0 + $1}
  使用引數名省略後的示例程式碼如下:

func calculate(opr :String)-> (Int,Int)-> Int {

    var result : (Int,Int)-> Int

    switch (opr) {
    case "+" :
    result = {$0 + $1}    //採用了引數名省略
    default:
    result = {$0 - $1}    //採用了引數名省略
    }
    return result
}

let f1:(Int,Int)-> Int = calculate("+")
print("10 + 5 = \(f1(10,5))")

let f2:(Int,Int)-> Int = calculate("-")
print("10 - 5 = \(f2(10,5))")

4、使用閉包返回值
  閉包表達本質上是函式型別,是有返回值的,我們可以直接在表示式中使用閉包的返回值。重新修改add和sub閉包,示例程式碼如下:

let c1:Int = {(a:Int, b:Int) -> Int in
                return a + b
                  }(10,5)   

print("10 + 5 = (c1)")

  解釋:給c1賦值,後面是一個閉包表示式。但是閉包表示式不能直接賦值給c1,因為c1是Int型別,需要閉包的返回值。這就需要在閉包結尾的大括號後面接一對小括號(10,5),通過小括號(10,5)為閉包傳遞引數。

歡迎關注關東昇新浪微博@tony_關東昇。 關注智捷課堂微信公共平臺,瞭解最新技術文章、圖書、教程資訊

enter image description here

更多精品iOS、Cocos、移動設計課程請關注智捷課堂官方網站:http://www.zhijieketang.com 智捷課堂論壇網站:http://51work6.com/forum.php

相關文章