逃离关闭在Swift

逃离关闭在Swift,第1张

概述我是Swift的新手,当我遇到逃避关闭时,我正在阅读手册。我没有得到手册的描述。有人可以用简单的方式向我解释Swift中的逃生关闭。非常感谢。 考虑这个类: class A { var closure: (() -> Void)? func someMethod(closure: () -> Void) { self.closure = closure } 我是Swift的新手,当我遇到逃避关闭时,我正在阅读手册。我没有得到手册的描述。有人可以用简单的方式向我解释Swift中的逃生关闭。非常感谢。 考虑这个类:
class A {    var closure: (() -> VoID)?    func someMethod(closure: () -> VoID) {        self.closure = closure    }}

someMethod将传入的闭包分配给类中的属性。

现在来了另一个类:

class B {    var number = 0    var a: A = A()    func anotherMethod() {        a.someMethod { self.number = 10 }    }}

如果我调用另一个方法,那么闭包{self.number = 10}将被存储在A的实例中。由于在闭包中被捕获,所以A的实例也将被强力引用。

这基本上是一个逃脱关闭的例子!

你可能想知道,“什么?那么关闭从哪里逃出来了?

闭包从方法的范围转移到类的范围。而且可以稍后再来,甚至在另一个线程上!如果处理不当,可能会导致问题。

为了避免意外逃脱关闭并导致保留周期和其他问题,请使用@noescape属性:

class A {    var closure: (() -> VoID)?    func someMethod(@noescape closure: () -> VoID) {    }}

现在如果你试图写self.closure =关闭,它不会编译!

更新:

在Swift 3中,默认情况下,所有闭包参数都不能退出。您必须添加@escaPing属性才能使闭包能够从当前作用域中转义。这为您的代码增加了更多的安全性!

总结

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

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

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

原文地址: http://outofmemory.cn/web/1054002.html

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

发表评论

登录后才能评论

评论列表(0条)

保存