Swift-非逃逸闭包

Swift-非逃逸闭包,第1张

概述非逃逸闭包//当一个闭包作为参数传到一个函数中,但是这个闭包在函数返回之后被执行,我们称该闭包从函数中逃逸。当你定义接受闭包作为参数的函数时,可以在参数名之前标注@noescape,用来指明这个闭包是不允许“逃逸”出这个函数的。//将闭包标注@noescape能使编译器知道这个闭包的生命周期//注:闭包只能在函数体中被执行,不能脱离函数体执行func someFunctionWithNoe
非逃逸闭包//当一个闭包作为参数传到一个函数中,但是这个闭包在函数返回之后被执行,我们称该闭包从函数中逃逸。当你定义接受闭包作为参数的函数时,可以在参数名之前标注@noescape,用来指明这个闭包是不允许“逃逸”出这个函数的。//将闭包标注@noescape能使编译器知道这个闭包的生命周期//注:闭包只能在函数体中被执行,不能脱离函数体执行func someFunctionWithNoescapeClosure(@noescape closure: () -> VoID) {    closure()}//一种能使闭包“逃逸”出函数的方法是,将这个闭包保存在一个函数外部定义的变量中。这种情况下,闭包需要“逃逸”出函数,因为闭包需要在函数返回之后被调用。//例:var completionHandlers: [() -> VoID] = []func someFunctionWithEscaPingClosure(completionHandler: () -> VoID) {    completionHandlers.append(completionHandler)}//someFunctionWithEscaPingClosure()函数接受一个闭包作为参数,该闭包被添加到一个函数外定义的数组中。//若你要是将这个参数标注为@noescape,你将会获得一个编译错误//将闭包标注为@noescape使你能在闭包中隐式的引用selfclass 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)
总结

以上是内存溢出为你收集整理的Swift-非逃逸闭包全部内容,希望文章能够帮你解决Swift-非逃逸闭包所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1080214.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-27
下一篇 2022-05-27

发表评论

登录后才能评论

评论列表(0条)

保存