Ale*_*kov 5 closures strong-references swift
我正在研究 ARC 和强引用循环,并遇到了我的这段代码:
class TestClass: UIView {
let button: UIButton = {
let view = UIButton()
view.frame = CGRect(x: 50, y: 50, width: 200, height: 200)
view.backgroundColor = .blue
view.translatesAutoresizingMaskIntoConstraints = false
view.setTitle("Button", for: .normal)
view.addTarget(self, action: #selector(buttonClicked), for: .touchUpInside)
return view
}()
@objc private func buttonClicked() {
print("Clicked")
}
override init(frame: CGRect) {
super.init(frame: frame)
print("Object of TestClass initialized")
}
required init?(coder aDecoder: NSCoder) {
fatalError("init(coder:) has not been implemented")
}
deinit {
print("Object of TestClass deinitialized")
}
}
Run Code Online (Sandbox Code Playgroud)
闭包内self的addTarget方法中的引用似乎不会创建强引用循环。
有人可以解释为什么吗?
另外,我注意到如果我从UIView编译器中删除继承开始抱怨:Use of unresolved identifier 'self'.
有人也可以解释一下,为什么在这种情况下会发生而在第一种情况下不会发生?
这不是一个保留周期,因为self它不是你想象的那样:)
具有初始值的属性甚至在任何初始化程序运行之前都会“执行”,并且这些属性self指向此类型的高阶函数:
(TestClass) -> () -> TestClass
Run Code Online (Sandbox Code Playgroud)
因此,您并没有真正访问实例,而是访问static类似方法,该方法对具有默认值的所有属性进行初始化。这就是为什么你没有保留周期。
addTarget接受Any?第一个参数的值,因此这不违反任何类型规则,因此编译器不会抱怨您没有NSObject在其中传递实例。
检查后面的行为 - 例如,如果按钮被添加到 UI 层次结构并被点击,会发生什么,揭示了一些有趣的事情:运行时发现您传递了一个非对象作为目标,并为目标和操作设置了空值:
| 归档时间: |
|
| 查看次数: |
760 次 |
| 最近记录: |