iOS開發(fā)中Swift逃逸閉包知識
逃逸閉包必須滿足下面2個條件:
1、閉包作為一個參數(shù)傳到函數(shù)中
2、閉包在函數(shù)返回之后才執(zhí)行
需要在參數(shù)前面加入標(biāo)注: @escaping,用來指明這個閉包是允許“逃逸”出這個函數(shù)的。
注意:將一個閉包標(biāo)記為 @escaping 意味著你必須在閉包中顯式地引用
import UIKit
/** 逃逸閉包滿足下面2個條件:
* 1、handle閉包作為一個參數(shù)傳到函數(shù)payRequest中
* 2、并且handle閉包在函數(shù)返回之后才執(zhí)行
* 需要在參數(shù)前面加入標(biāo)注: @escaping,用來指明這個閉包是允許“逃逸”出這個函數(shù)的
* 注意:將一個閉包標(biāo)記為 @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標(biāo)準(zhǔn)庫中,有很多這種類型的閉包,比如下面的異步請求的方法:
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
都符合文章開頭提到的逃逸閉包的形成條件。
相關(guān)文章
一個iOS上的秒表小應(yīng)用的實現(xiàn)方法分享
這篇文章主要介紹了一個iOS上的秒表小應(yīng)用的實現(xiàn)方法分享,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-10-10
iOS開發(fā)中使app獲取本機通訊錄的實現(xiàn)代碼實例
這篇文章主要介紹了iOS開發(fā)中使app獲取本機通訊錄的實現(xiàn)代碼實例,主要用到了AddressBook.framework和AddressBookUI.framework,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2016-01-01
IOS開發(fā)仿微信右側(cè)彈出視圖實現(xiàn)
這篇文章主要介紹了IOS開發(fā)仿微信右側(cè)彈出視圖實現(xiàn)的相關(guān)資料,希望通過本文能幫助到大家,讓大家實現(xiàn)這樣類似的功能,需要的朋友可以參考下2017-10-10

