说到Timer定时器不得不说说,Timer造成的循环引用。当我们跳转到一个VC时,在这个VC创建一个重复触发的定时器,当从这个VC返回时,发现VC的delloc方法并未调用,这是因为timer对VC的强引用导致VC无法释放。
解决这中问题的关键就是让Timer解除对VC的强引用。
首先想到的:
1.破除循环引用只要断开一方就可以了呀?所以在VC中把Timer的属性修饰符,由strong变为weak;
想一想,是因为Runloop强引用了Timer,而Timer又强引用的VC。把timer属性变为weak并没有改变Timer对VC的强引用,所以VC想要释放,Timer是一定要invalidate的,所以这样的做法是无效的。
2.在方法的target中传入__weak修饰的VC;
这样乍一看貌似可以,
但是,Block 中只是对变量 weakSelf 拷贝了一份,是拷贝变量而不是拷贝对象。即 Block 中也新定义了一个 weakSelf 对象,内部实现代码类似这样__weak blockWeakSelf = weakSelf;,对象的 retainCount 没有变化。如果拷贝的是 self,那么 Block 内部实现代码类似这样__strong blockStrongSelf = self;,strong 类型的拷贝操作是会使对象的 retainCount 加1的
NSTimer中: