以下是您可以在游乐场中运行的代码示例 import Foundationclass TempNotifier { var onChange: (Int) - Void = {t in } var currentTemp = 72 init() { // 1. onChange = { [unowned self] temp in self.currentTemp = temp } // 2. onChan
import Foundation class TempNotifier { var onChange: (Int) -> Void = {t in } var currentTemp = 72 init() { // 1. onChange = { [unowned self] temp in self.currentTemp = temp } // 2. onChange = {[unowned self] temp in self.tempHandler(temp) } // 3. unowned let s = self onChange = s.tempHandler } deinit { println("deinit") } private func tempHandler(temp: Int) { self.currentTemp = temp } } var tN: TempNotifier? = TempNotifier() tN = nil
它说明了为具有潜在保留周期的块分配值的3种方法.情况1.和2.由于无主自我而没有创建保留周期,但是在情况3中,似乎没有办法打破保留周期(deinit从不打印).如您所见,我甚至尝试创建一个本地无主参考.
这是理想的行为,是“按设计”吗?或者我错过了什么?
谢谢!
从https://devforums.apple.com/message/1122247交叉发布
是的,这是设计的行为.访问一个不调用它的方法,比如s.tempHandler,等同于一个闭包表达式,如{x in s.tempHandler(x)}.这里s没有标记为无主或弱,因此由闭合保留.如果您希望将其捕获为无主或弱,则必须明确写出闭包.