逃逸閉包必須滿足下面2個條件:
1、閉包作為一個參數傳到函數中
2、閉包在函數返回之后才執行
需要在參數前面加入標注: @escaping,用來指明這個閉包是允許“逃逸”出這個函數的。
注意:將一個閉包標記為 @escaping 意味著你必須在閉包中顯式地引用
import UIKit/** 逃逸閉包滿足下面2個條件: * 1、handle閉包作為一個參數傳到函數payRequest中 * 2、并且handle閉包在函數返回之后才執行 * 需要在參數前面加入標注: @escaping,用來指明這個閉包是允許“逃逸”出這個函數的 * 注意:將一個閉包標記為 @escaping 意味著你必須在閉包中顯式地引用 self */func payRequest(handle:@escaping (Data?, URLResponse? ,Error?) -> Void) { let urlStr = URL(string: "http://www.baidu.com") let session = URLSession(configuration: .default) session.dataTask(with: urlStr!, completionHandler: handle)}func someFunctionWithNonescapingClosure(closure: () -> Void) { closure()}class SomeClass { var x = 10 func doSomething() { payRequest { (data, resp, error) in x = 100 // 此處編譯錯誤,必須顯式地引用 self } someFunctionWithNonescapingClosure { x = 200 } }}
在Swift標準庫中,有很多這種類型的閉包,比如下面的異步請求的方法:
open func dataTask(with request: URLRequest, completionHandler: @escaping (Data?, URLResponse?, Error?) -> Swift.Void) -> URLSessionDataTask
open func dataTask(with url: URL, completionHandler: @escaping (Data?, URLResponse?, Error?) -> Swift.Void) -> URLSessionDataTask
都符合文章開頭提到的逃逸閉包的形成條件。
新聞熱點
疑難解答