Swift---逃逸闭包

    当一个闭包作为参数传到一个函数中,但是这个闭包在函数返回之后才被执行,则称该闭包从函数中逃逸。当定义接受闭包作为参数的函数时,可以在参数名之前标注@escaping,用来指明这个闭包是允许‘逃逸’出这个函数的。

    很多异步操作的函数接受一个闭包参数作为completion handler,这类函数会在异步操作开始之后立即返回,但是闭包直到异步操作结束后才会被调用,这种情况下,闭包需要‘逃逸’出函数,因为闭包需要在函数返回之后被调用。

func someFunctionWithEscapingClosure(completionHandler: @escaping () -> Void) {
    completionHandler()
}

    将一个闭包标记为@escaping,意味着你必须在闭包中显式的引用self;如果是非逃逸闭包,可以隐式引用self。

// 非逃逸闭包
func someFunctionWithNonescapingClosure(closure: () -> Void) {
    closure()
}

class SomeClass {
    var x = 10
    func doSomething() {
         // 逃逸闭包显式引用self
        someFunctionWithEscapingClosure { self.x = 100 }
        // 非逃逸闭包隐式引用self
        someFunctionWithNonescapingClosure { x = 200 }
    }
}

你可能感兴趣的:(Swift---逃逸闭包)