很多iOS开发的朋友都是比较关心内存泄漏的问题,在实际的开发工作中首先我们需要知道程序有没有内存泄露,然后定位到底是哪行代码出现内存泄露了,这样才能将其修复。最简单的方法当然是借助于专业的检测工具,比较有名如BoundsCheck工具,功能非常强大。

  内存的泄漏是会关系到线上的稳定性和性能。内存泄露将会是导致这样的情况发生:

  1.若是内存资源不足发生难以排查的线上bug

  2.被泄露对象的存在,将会是导致的一些业务bug,例如是泄露的对象它们是仍在接受全局的一个通知

  3.一些性能问题,是会导致用户使用app时越来越卡

  内存泄露发现分成静态扫描和运行时检测,本文主要讲运行时检测。

  关于静态扫描

  常用的一些静态扫描的工具:

  xcode analyzer

  OCLint

  Infer

  运行时动态检测

  因为在静态扫描不能发现所有的内存泄露问题,因此在运动时检测,是必不可少的一个操作。

  Allocation

iOS uitextfield内存泄漏 ios try catch 内存泄露_iOS

  Xcode中的的Allocation是可以通过比较不同时间段的对象,用来是分析出是否发生了一些内存泄露。前提必须是每个页面的命名要符合规范,就比如说宝贝详情页的所有对象,这些都是应用的前缀+宝贝详情页面前缀+具体对象名,当退出页面的时候才会是知道相应的对象是否被释放了,那是因为stack最底部的页面的对象经常是驻在内存中。

  Allocation是通过和Monkey配合,当在回归测试的时候,会自动运行并通过计算内存占用率,就可以判断出新的开发版本是否发生了内存泄露,但是无法知道具体是哪个对象没有释放,局限性就是只能通过全局的一个判断。

  重点是如何排查?

  当发现了内存泄露后,排查并解决,这才是最关键的一步。开发者是根据泄露的对象,重点的去排查block和两个以上对象循环引用的最终情况。

  发现是ViewController发生内存泄露,就要是重点的去查看一下ViewController里面的block是否忘记声明weak了,当ViewController被其他对象持有的情况不常见。因此若是用RAC的话,这就要去记得weakly和strongly要成对出现,否则将会是发生内存的泄露。

  实际上最常发生的是View的内存泄露问题,首先查看是发生内存泄露的view之间是否有delegate的关系,若有,则去看delegate属性有没有声明weak,一般的由于service或者读取缓存等异步操作引起的内存泄露问题。

  解决内存泄漏的问题最主要的还是在编码的时候尽量的做到规范一些,学会利用工具去排查是积累经验的有效手段,静态扫描能解决一部分问题,动态扫描是最后的保证。