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

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

内容简介:最近玩儿了一下百度人脸识别的功能,申请了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左右的样子。

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


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

查看所有标签

猜你喜欢:

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

孵化Twitter

孵化Twitter

[美]尼克·比尔顿(Nick Bilton) / 欧常智、张宇、单旖 / 浙江人民出版社 / 2014-1 / 49.90元

一个在挣扎中生存的博客平台Odeo,一小撮龙蛇混杂的无政府主义者员工,经历了怎样的涅槃,摇身一变,成为纽交所最闪耀的上市企业Twitter? 一个野心勃勃的农场小男孩,一个满身纹身的“无名氏“,一个爱开玩笑的外交家,一位害羞而又充满活力的极客,这四位各有特色的创始人如何从兢兢业业、每日劳作的工程师,成为了登上杂志封面、奥普拉秀和每日秀的富裕名人?而在Twitter日益茁壮成长的过程中,他们又......一起来看看 《孵化Twitter》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

在线进制转换器
在线进制转换器

各进制数互转换器

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具