2017-12-1

TODO  List:

1.Try to finish clean up all git and fabric issue.2

2.Write an article about the Memory performance optimization

Actual List:

1.Still pending for the git and fabric issues.

Memory Optimization

前言:最近遇到iPad在刚启动之后,过1分钟就会Crash的问题,然后在Fabric上查不到对应的崩溃栈信息。根据经验,找不到Crash要么是系统安全退出(切换设置),要么就是OOM。

调查:1.首先这个crash 是可以稳定重现的,这个是能修复该逻辑的前提

            2.通过观察在控制台的log输出情况发现了:

Nov 30 16:09:18 -iPad MyApp(UIKit)[35527]: Received memory warning.

Nov 30 16:09:25 -iPad SpringBoard(FrontBoard)[4918]:was killed by jetsam.

Nov 30 16:09:25 -iPad SpringBoard[4918]: Process exited:->

就在收到Memory Warning 时便被杀掉,这样就可以断定是OOM引起的。

分析:1.确定了是OOM之后,我们左手开始分析原因

Activity Monitor: 能给从全局看到当前App在整个设备中的使用情况,包括真实占用内存(当然也可以看到在应用被杀掉 的内存情况),线程数量,CPU使用情况等。

Allocations:在使用AM有了一个总体概括是,这时候需要使用它对内存分配能够比较细致的观察,它提供了几个比较有用的视图:

Statistics: 可以看到整个看到整个内存配分对象的概况

CallTree:个人觉得非常有用,特别是配合“Invert Call Tree” 和 “Hide the system libraries”使用时,能给帮助你很快定位到耗内存最多的对象是如何通过应用代码调用过去的。(同理也可以应用在Time Profile).

Allocations:能给比较细致地

2.通过用Call Tree 视图分析发现是由于开机后反复大量调用该方法造成的问题,自此找到了核心问题点。

3.总结:个人认为解决内存或CPU问题的核心在于:

                    1.能稳定重现(包括固定的起始点),比如每次开机之后什么都不做过30s就崩溃

                    2.使用Activity Monitor 粗略且全局观察应用当前的内存/CPU消耗,从而了解到这一问题带来的内存/CPU开销值

                    3.使用 如Allocations/Time Profiler 进行细节调查,按照消耗内存最多/CPU最多排序,快速定位应用代码中最多的调用

                    4.定位到问题代码后,通过尝试简单去掉,观察是否解决了这一问题,如果是,找到优化这块代码的方法,如果否,说明并没有找到根源,需要重复步骤3.

                    5.完成步骤四之后,我们可以在使用Activity Monitor记录优化后的结果,以便可以跟优化前做对比。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,847评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,208评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,587评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,942评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,332评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,587评论 1 218
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,853评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,568评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,273评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,542评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,033评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,373评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,031评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,073评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,830评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,628评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,537评论 2 269

推荐阅读更多精彩内容