通过协议传递自我会导致内存泄漏吗?

Ale*_*scu 0 ios swift

我在解决这个问题时遇到了一些困难

假设我有一个自定义视图,其中包含要由另一个类使用的协议(视图控制器)

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中我继续采取措施,然后从其视图中删除发件人(子视图),则子视图是否会从内存中重新分配?

mat*_*att 5

仅当引用的接收者在一段时间内保留该引用时,才可能导致内存泄漏。当您调用时delegate?.parentNeedsToTakeAction(self),该方法parentNeedsToTakeAction运行时间非常短,然后结束。self随着时间的推移,不会保留任何引用,因此没有泄漏的危险。