关于逃逸闭包

逃逸闭包:当函数执行结束后,才去调用函数内部的闭包,叫做逃逸闭包非逃逸闭包当函数执行过程中,执行的函数内部的闭包,叫做非逃逸闭包 @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表示。

你可能感兴趣的:(关于逃逸闭包)