1)不执行dealloc
1.查看是不是循环引用造成的类不销毁
2.调用其他类的时候查看有没有将本类中的对象传过去,例如self,self.tableview
传的时候注意使用weak,不要使用strong
否则会造成当前类无法释放,dealloc不执行一直占用内存。
下面我们看一下,怎么样就会循环引用,以及怎样处理这种情况
上图的方法,实在UIViewController中的方法,我们可以看到API与self是不存在持有关系的,但是这个block块,持有API,他们三者之间关系不是互相持有的关系,所以在块中,[self.dataArray addObject:dic]是不会导致循环引用,也就不需要处理
我们看这个图,_pickView是vc的属性,这样他们的关系,如上图,他们这种互相持有,就会导致循环引用,导致内存泄漏。下面我们看解决方法
就这样简单写一个弱引用,当对象不存在,弱指针指向的这个对象也就没有了,不会说调用该对象的某个方法,将他的retainCount给+1,导致这个对象不能释放问题
3.performSelector 关于内存管理的执行原理是这样的执行
[self performSelector:@selector(method1:) withObject:self.tableLayer afterDelay:3]; 的时候,系统会将tableLayer的引用计数加1,执行完这个方法时,还会将tableLayer的引用计数减1,由于延迟这时tableLayer的引用计数没有减少到0,也就导致了切换场景dealloc方法没有被调用,出现了内存泄露。
利用如下函数:
[NSObject cancelPreviousPerformRequestsWithTarget:self] 当然你也可以一个一个得这样用:
[NSObject cancelPreviousPerformRequestsWithTarget:self selector:@selector(method1:) object:nil]
加上了这个以后,顺利地执行了dealloc方法
4.NSTimer使用造成的内存泄露。
注意自己需要管理NSTimer停止与释放,否则,会一直运行,导致页面内存不释放。
举个栗子: 在自定义View中,如果不手动停止NSTimer对象,那么会一直NSTimer会一直持有这个类,导致内存不释放,也就是内存泄露。
解决方法:
在controller中手动调用removeFromSuperView,重写
- (void)removeFromSuperview 把_timer 停止释放。
- (void)removeFromSuperview {
[super removeFromSuperview];
[_timer invalidate];
_timer =nil;
}
对于NSTimer这种问题,我们可以写一个分类 YYKit中类别就可以避免这种情况
也可以看看下面
[带你点点]//www.greatytc.com/p/a1312c1653aa
[此人是土豪,快勾搭]//www.greatytc.com/u/c86325c3ac19