我在解决这个问题时遇到了一些困难
假设我有一个自定义视图,其中包含要由另一个类使用的协议(视图控制器)
protocol MyViewDelegate : AnyObject {
func parentNeedsToTakeAction(sender: MyView)
}
class MyView : UIView {
...
weak var delegate : MyViewDelegate?
....
func initiateCallBack(){
delegate?.parentNeedsToTakeAction(self)
}
}
Run Code Online (Sandbox Code Playgroud)
并且视图控制器符合该视图的委托
在将自身传递回VC之前,我知道VC拥有对视图的强引用,而视图仅拥有对VC的弱引用(通过委托)。
但是之后会发生什么呢?该视图的ARC现在是2还是仍然是1,VC是否拥有对该视图的1或2个强引用?
如果在VC中我继续采取措施,然后从其视图中删除发件人(子视图),则子视图是否会从内存中重新分配?
仅当引用的接收者在一段时间内保留该引用时,才可能导致内存泄漏。当您调用时delegate?.parentNeedsToTakeAction(self),该方法parentNeedsToTakeAction运行时间非常短,然后结束。self随着时间的推移,不会保留任何引用,因此没有泄漏的危险。
| 归档时间: |
|
| 查看次数: |
65 次 |
| 最近记录: |