dealloc 不执行或延迟执行的问题

1)不执行dealloc 

1.看一下是不是循环引用造成的类不销毁

2.调用其他类的时候查看有没有将本类中的对象传过去,例如self,self.tableview   

传的时候注意使用weak,不要使用strong

否则会造成当前类无法释放,dealloc不执行一直占用内存。

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];

    [_timerinvalidate];

    _timer =nil;

}

2)延迟执行dealloc 

本地在类撤销之前有延时操作,未执行完

比如:

[self performSelector:@selector(xx) withObject:nil afterDelay:10.0];

虽然现在大部分都是ARC工程,系统帮你处理内存管理,但这不等于开发者不用管理内存。比如通知的移除、baiduSDK中的变量置nil等都需要重写dealloc方法来实现。注意,ARC工程是可以重写dealloc方法并被系统调用的,但不需要手动调用父类的dealloc,手写[super dealloc]方法会报错,事实上系统会自动帮你调用父类的dealloc方法,不需要你实现。

但有些时候会发现控制器出栈的时候不会调用dealloc方法,归根结底,是因为当前控制器被某个对象强引用并“握住”了,控制器的引用计数不为0,系统无法帮你释放这部分内存。

控制器被强引用的原因:

1.block块使用不当。因为block会对方法中的变量自动retain一次。请检查控制器中block代码。

2.NSTimer没有销毁。

3.控制器中的代理属性为retain。应把代理属性改为assign。

目前遇到这些问题,日后遇到新的问题再添加上去.

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 下面我们看一下,怎么样就会循环引用,以及怎样处理这种情况 上图的方法,实在UIViewController中的方法...
    未来可期me阅读 11,350评论 0 6
  • 1.设计模式是什么? 你知道哪些设计模式,并简要叙述? 设计模式是一种编码经验,就是用比较成熟的逻辑去处理某一种类...
    司马DE晴空阅读 5,113评论 0 7
  • 1.自定义控件 a.继承某个控件 b.重写initWithFrame方法可以设置一些它的属性 c.在layouts...
    圍繞的城阅读 8,819评论 2 4
  • 问:乔大,想超过竞争对手,他的访客需要每个流量来源都统计出来吧? 答:在做一款产品前或者在产品推广过程中,时时关注...
    1ff17b674958阅读 1,235评论 0 0
  • 今天是8月30号,星期三,农历七月初九。和往常一样,五点多就醒了。今天我晨运的地点和往常不一样。他就是在广东省英德...
    曾心想事成阅读 1,170评论 0 1