iOS内存泄露与内存优化

一.哪些时候会出现内存泄露

1.声明delegate为strong类型,简而言之,如果父VC持有子VC,并设置子VC的delegate为self(也就是父VC),这样的结果就是子VC也间接持有了父VC,造成循环引用,在Pop子VC的时候不会调用delloc。

2.timer是否持有self,我们一般要执行一个timer的时候会用
(NSTimer *)scheduledTimerWithTimeInterval:(NSTimeInterval)ti target:(id)aTarget selector:(SEL)aSelector userInfo:(id)userInfo repeats:(BOOL)yesOrNo
这里的aTarget一般是self,这时候就需要注意了,如果在你退出的时候这个timer还在执行的话由于这个timer会持有self,所以delloc也不会调用,这里可以用weakSelf代替self也是没有问题的。

3.最常见的就是block导致的循环引用,__weak type(self) weakSelf = self,在block中用weakSelf就可以了。

4.图片没释放,instrument调试后,发现没被释放的全是imageIO,imageNamed 会cache 先从内存中取出图片 如果内存中不存在 就从缓存到内存才能中imageWithContentOf 只会加载文件不会缓存所以较大的图片,还是用imageWithContentsOfFile。

  • TIPs1:.xcassets里的图片无法用imageWithContentsOfFile读取;
  • TIPs2:imageWithContentsOfFile读取图片需要加文件后缀名如png,jpg等;

5.CoreFoundation对象(C对象) : 只要函数中包含了create\new\copy\retain等关键字, 那么这些方法产生的对象, 就必须在不再使用的时候调用1次CFRelease或者其他release函数。

内存优化

即使内存不发生泄露,在某些情况下,我们也需要对内存使用进行优化。

1.内存优化的常用方法实例。
  • cell 复用API dequeueReusableCellWithIdentifier 和 非复用API cellForRowAtIndexPath 两个api 复用
  • 轮播图,能复用就复用
  • 内嵌autorelease pool
2.内存检测工具
analyze

Analyze主要分析以下四种问题:
1、逻辑错误:访问空指针或未初始化的变量等;
2、内存管理错误:如内存泄漏等; 比如ARC下,内存管理不包括core foundation
3、声明错误:从未使用过的变量;
4、Api调用错误:未包含使用的库和框架。
缺点: 静态内存分析由于是编译器根据代码进行的判断, 做出的判断不一定会准确, 因此如果遇到提示, 应该去结合代码上文检查一下,使用略。

instrument leaks

有时使用静态分析能够检查出一些内存泄露问题,但是有时只有运行时使用Instruments才能检查到。使用略。

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

推荐阅读更多精彩内容