逃逸闭包必须满足下面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
都符合文章开头提到的逃逸闭包的形成条件。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎点击右下角反馈进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。