逃逸闭包:当函数执行结束后,才去调用函数内部的闭包,叫做逃逸闭包
非逃逸闭包:当函数执行过程中,执行的函数内部的闭包,叫做非逃逸闭包 @noescape
import UIKit
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
loadData { (json: [String]) in
print(json)
}
setupUI { (result) in
print(result)
}
}
func loadData(completion:@escaping (_ : [String])->()) {
DispatchQueue.global().async {
print("当前的现成\(Thread.current))")
Thread.sleep(forTimeInterval: 3)
let json = ["lausen"]
DispatchQueue.main.async {
print("当前的现成\(Thread.current)");
completion(json)
}
print("执行到这儿结束了") //函数结束后才去调用的闭包这个就是逃逸闭包
}
}
func setupUI(completion: (_ : [String]) -> ()) { //而这个就是非逃逸闭包
let json = ["liuxiang","lausen","somnus"]
completion(json)
}
}
注意:写闭包参数的时候,很容易忽略去判断这个闭包是不是逃逸的,这对闭包的内存管理很不友好,都当做了逃逸闭包处理,所以在Swift3中做除了一个对调的改变,所有的闭包都默认为非逃逸的,不在需要@noescape;如果是逃逸闭包,就用@escaping表示
菜鸟一只,不足之处,还望同行不吝赐教