利用Instruments中的Leaks处理内存泄露

这两天医生端第一版开发完了,正在进行测试。由于上个健康管理卫士是写的第一个项目,项目中的代码非常的乱。所以在医生端,自己尝试着对必要的模块进行了封装,例如网络请求、提示框等在原有三方库的基础上进行了二次封装, 并且把网络层完全的抽离了出来,方便统一管理。

但是最近测试的时候发现有很严重的内存泄露和循环引用情况发生。(/(ㄒoㄒ)/~~block用的有点乱了。)

简直是一步三泄...

分析了下,
1、首先是,在block中使用非私有成员变量的时候忘记加上

 __weak typeof(self)weakself = self;  //这一块在block中使用成员变量的时候需要加一下,关于这部分详细的解释可以看一下https://www.cnblogs.com/biosli/p/block_usage.html

导致了对象不能及时释放,造成了循环引用。(原谅我犯得小白错误/(ㄒoㄒ)/~~,后续要抓紧学习学习相关知识🐒🐒🐒)。

2、还有就是项目中使用了AFNetworking3.0,我在这个基础上又进行了封装,封装的时候使用的方法,存在问题。(好吧,第一次尝试果然有好多坑..后续慢慢填=。 = )。
大概是这样的,


  分析出来的泄漏点基本都跟网络部分有关,好吧看来真的是封装问题了。😢😢😢
  看了一下AFNetworking的官方demo,在网上找了点资料发现封装的时候基本使用的都是单例模式来创建AFHTTPSessionManager。而我封装的每次使用的时候都会创建一个AFHTTPSessionManager,像这样:

好吧应该是这里的问题,接着就把请求改成了单例模式。果然改成单例模式以后内存泄露点瞬间就只剩一个了,瞬间感觉世界清晰了好多。


改过之后:

(可是还有一个怎么办,看到叉号和减号感觉好纠结..强迫症么这是.😭😭😭😭。好吧只有继续查哪一块出错了..)

一查call Tree 是这个样子,当时就懵逼了...这是啥..main出错这怎么玩...



好吧,点进去一看猜是AppDelegate里面哪个地方出错了.只好一步一步排查了..(😭😭😭)



好吧,,最后定位在链接融云这一块,

融云的解释是这样的:

好吧,经过测试链接融云这一步。连接上的情况下会一直出现上面那个内存泄露点,失败或者将这部分屏蔽的时候不存在内存泄露情况。(哪位遇到过这个情况,求指教.😢😢😢)(PS. 这个问题解决了,更新成融云最新版本以后,这个内存泄露点已经解决。现在终于全绿了😂😂😂)


努力进阶中/(ㄒoㄒ)/~~..

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

推荐阅读更多精彩内容