非逃逸闭包 //当一个闭包作为参数传到一个函数中,但是这个闭包在函数返回之后被执行,我们称该闭包从函数中逃逸。当你定义接受闭包作为参数的函数时,可以在参数名之前标注@noescape,用来指明这个闭包是不允许“逃逸”出这个函数的。 //将闭包标注@noescape能使编译器知道这个闭包的生命周期 //注:闭包只能在函数体中被执行,不能脱离函数体执行 func someFunctionWithNoescapeClosure(@noescape closure: () -> Void) { closure() } //一种能使闭包“逃逸”出函数的方法是,将这个闭包保存在一个函数外部定义的变量中。这种情况下,闭包需要“逃逸”出函数,因为闭包需要在函数返回之后被调用。 //例: var completionHandlers: [() -> Void] = [] func someFunctionWithEscapingClosure(completionHandler: () -> Void) { completionHandlers.append(completionHandler) } //someFunctionWithEscapingClosure()函数接受一个闭包作为参数,该闭包被添加到一个函数外定义的数组中。 //若你要是将这个参数标注为@noescape,你将会获得一个编译错误 //将闭包标注为@noescape使你能在闭包中隐式的引用self class SomeClass { var x = 10 func doSomething() { someFunctionWithEscapingClosure { self.x = 100 } someFunctionWithNoescapeClosure { x = 200 } } } let instance = SomeClass() instance.doSomething() print(instance.x) completionHandlers.first?() print(instance.x)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。