iOS-记一次因内存泄露引起的崩溃

栏目: 编程工具 · 发布时间: 6年前

内容简介:最近玩儿了一下百度人脸识别的功能,申请了iOS SDK放到了测试的app里面。本来都运行得挺好的,把人脸识别的界面放在那儿,中午出去吃个饭回来发现app崩溃了!!!这就要找一下原因了,肯定不是什么每次都必现的bug,不然不可能一开始好好的,后来却崩溃了。

最近玩儿了一下百度人脸识别的功能,申请了iOS SDK放到了测试的app里面。

本来都运行得挺好的,把人脸识别的界面放在那儿,中午出去吃个饭回来发现app崩溃了!!!

这就要找一下原因了,肯定不是什么每次都必现的bug,不然不可能一开始好好的,后来却崩溃了。

一、查看设备上面的日志

把设备连上电脑,打开 Xcode -> Windows -> Devices and Simulators ,找到相应的设备,点击 View Device Logs

看了一下,只有一些前几天的crash日志,和一些 unkown 的没有日期的日志。

这条路是看不出什么了。

二、集成SDK统计崩溃信息

我先是集成了百度移动统计的SDK,QA帮忙测了一会儿说又崩溃了,打开移动统计后台,什么崩溃信息也没有!!!

三、查看内存使用

上面两条路走不通之后,我想着就试试是不是内存的原因。

本来想打开 Instrument 看一下内存是情况,但是一运行就崩溃。。。。没事儿不纠结,反正还可以在Xcode里面看

iOS-记一次因内存泄露引起的崩溃

测试过程中,启动了app之后只占20MB的内存,但是一打开人脸识别功能,瞬间飙到了190MB。但是190MB还不足以触发 didReceiveMemoryWarning

试了一会儿,发现每次识别一个人脸,内存都只增不减,试了几十次之后,内存占用慢慢升到了300MB。照理说,在人脸识别服务空闲期间,内存应该回落。

这就定位到了是应该是某些内存没有释放。经过仔细筛查代码,我发现是我截图取出人脸的时候(代码如下),没有释放图片

CGImageRef croped = CGImageCreateWithImageInRect(image.CGImage, faceRect);
UIImage* face = [UIImage imageWithCGImage:croped];

在这个后面加上这一句 CGImageRelease(croped); 之后,会释放图片。

这样一来,在人脸识别功能运行期间,内存就基本保持在200MB左右的样子。

试了一下从早上到晚上都运行着,没有中途崩溃


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Learn Python the Hard Way

Learn Python the Hard Way

Zed Shaw / Example Product Manufacturer / 2011

This is a very beginner book for people who want to learn to code. If you can already code then the book will probably drive you insane. It's intended for people who have no coding chops to build up t......一起来看看 《Learn Python the Hard Way》 这本书的介绍吧!

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具