在Swift中阻塞保留周期?
发布时间:2020-12-14 06:09:25 所属栏目:百科 来源:网络整理
导读:传统上在Objc中,我们做weakSelf以防止块的额外保留计数。 Swift如何在内部管理Objc的块中出现的保留周期? 要防止块保存对对象的强引用,必须为该块定义捕获列表。 闭包表达式语法定义如下: { ( /*parameters*/ ) - /*return type*/ in // statements} 但
传统上在Objc中,我们做weakSelf以防止块的额外保留计数。
Swift如何在内部管理Objc的块中出现的保留周期?
要防止块保存对对象的强引用,必须为该块定义捕获列表。
闭包表达式语法定义如下: { ( /*parameters*/ ) -> /*return type*/ in // statements } 但是这在文档中稍后会扩展以包括捕获列表。这实际上等同于表达式语法定义如下: { [ /*reference type*/ /*object*/,... ] ( /*parameters*/ ) -> /*return type*/ in // statements } …其中/ *引用类型* /可以是weak或unowned。 捕获列表是在闭包中出现的第一个东西,它是可选的。如上所示的语法被定义为一对或多对引用类型,后跟对象;每对由逗号分隔。例如: [unowned self,weak otherObject] 完整示例: var myClosure = { [unowned self] in print(self.description) } 请注意,非所有者引用是非可选的,因此您不需要解开它。 希望这回答了你的问题。你可以在documentation的相关章节中阅读关于ARC的更多信息。 你应该特别注意弱和无主的区别。在你的实现中使用weak可能更安全,因为使用unowned假定对象永远不会是nil。这可能导致您的应用程序崩溃,如果对象实际上已被释放,然后在您的闭包中使用。 使用weak作为参考类型,你应该用?解开,如下: var myClosure = { [weak self] in print(self?.description) } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |