INSTRUMENTS调试工具的使用(二十八) —— 分析你App的内存使用之找到废弃的内存(三)

版本记录

版本号 时间
V1.0 2018.06.15

前言

我们在做app的时候,不是做完功能就结束了,很多时候是需要进行检查和优化的,而xcode自带了一个很好的检查工具,可以检测内存泄漏。还可以查看哪一个方法比较耗时。还可以检测离屏渲染等等,随后的几篇我们就说一下这个工具的使用。感兴趣的可以看这几篇。
1.INSTRUMENTS调试工具的使用(一)
2.INSTRUMENTS调试工具的使用(二)
3.INSTRUMENTS调试工具的使用(三)
4.INSTRUMENTS调试工具的使用(四)
5.INSTRUMENTS调试工具的使用(五)
6.INSTRUMENTS调试工具的使用(六)
7.INSTRUMENTS调试工具的使用(七)
8.INSTRUMENTS调试工具的使用(八)
9.INSTRUMENTS调试工具的使用(九)
10. INSTRUMENTS调试工具的使用(十)
11. INSTRUMENTS调试工具的使用(十一) —— 简介(一)
12. INSTRUMENTS调试工具的使用(十二) —— 通常任务之启动Instruments(一)
13. INSTRUMENTS调试工具的使用(十三) —— 通常任务之简单了解Instruments(二)
14. INSTRUMENTS调试工具的使用(十四) —— 通常任务之创建、保存和打开跟踪文档(三)
15. INSTRUMENTS调试工具的使用(十五) —— 通常任务之指定目标应用和设备(四)
16. INSTRUMENTS调试工具的使用(十六) —— 通常任务之访问和使用个别仪器(五)
17. INSTRUMENTS调试工具的使用(十七) —— 通常任务之记录、暂停和停止跟踪(六)
18. INSTRUMENTS调试工具的使用(十八) —— 导航收集的数据之关于数据分析(一)
19. INSTRUMENTS调试工具的使用(十九) —— 导航收集的数据之导航时间轴窗格(二)
20. INSTRUMENTS调试工具的使用(二十) —— 导航收集的数据之导航详细面板(三)
21. INSTRUMENTS调试工具的使用(二十一) —— 导航收集的数据之将数据映射到源代码(四)
22. INSTRUMENTS调试工具的使用(二十二) —— 导航收集的数据之查看您应用的源代码(五)
23. INSTRUMENTS调试工具的使用(二十三) —— 分析你App的性能之测量CPU使用情况(一)
24. INSTRUMENTS调试工具的使用(二十四) —— 分析你App的性能之测量图形性能(二)
25. INSTRUMENTS调试工具的使用(二十五) —— 分析你App的性能之监视网络和文件I / O(三)
26. INSTRUMENTS调试工具的使用(二十六) —— 分析你App的内存使用之关于内存分析(一)
27. INSTRUMENTS调试工具的使用(二十七) —— 分析你App的内存使用之检测内存使用(二)

Find Abandoned Memory - 找到废弃的内存

Allocations分析模板使​​用AllocationsVM Tracker工具来测量应用程序中的一般和虚拟内存使用情况。但是,为了追踪已分配但不再需要的废弃内存,请严格关注Allocations工具。该仪器测量堆内存使用情况并跟踪分配,包括按类分配的特定对象。

由于废弃的内存仍然是您的应用程序引用的,因此Instruments无法确定其重要性。要找到废弃的内存,请使用generational分析来确保内存在继续增长的同时反复执行相同的操作。例如,结束和开始新游戏,打开和关闭窗口,创建和删除联系人,或者设置和取消设置首选项都是应该从理论上将您的应用程序恢复到以前的稳定内存状态的操作。通过这种操作进行多次循环不应导致意外或不受限制的内存增长。Instruments可帮助您将内存增长时间与特定对象分配关联起来,因此您可以释放它们并减少应用程序的内存占用量。

To look for abandoned memory in your app - 在您的应用中寻找遗弃的内存

  • 1)启动仪器。
  • 2)在出现的分析模板选择对话框中,单击Allocations
  • 3)从目标设备和进程列表中选择您的设备和应用程序。
  • 4)点击Choose创建一个跟踪文档。
  • 5)单击时间轴窗格中的Allocations工具。
  • 6)按Command-2显示检查器窗格的显示设置区域。这使您可以快速访问Mark Generation按钮,您可以在分析应用程序时标记不同代的操作。
  • 7)单击工具栏中的录制按钮(或按下Command-R)开始录制。
  • 8)在您的应用中执行一系列可重复操作。为了准确地生成趋势,这应该是一组以同一状态下的应用程序开始和结束的操作。
  • 9)单击检查器窗格中的Mark Generation按钮。轨迹窗格中会出现一个标志来标识这一代。详细信息窗格中显示您标记的generations列表。每一代都包括自上一代以来发生的分配清单。通过将跟踪窗格的时间线中的检查头拖到所需的位置并单击标记生成,您也可以在记录完成后标记generations
  • 10)在监视详细信息窗格的同时,多次执行步骤8和9,直到您看到内存是否正在无限增长。

重要:在前几次迭代中,由于缓存可能会发生额外的allocations。 因此,为了建立一个基线,创建前几代是非常重要的。 然后,为真正的分析创造更多的generations

  • 11)当您准备停止录制时,单击工具栏中的停止按钮(或再次按下Command-R)。
  • 12)浏览细节窗格中的generations,找到一个似乎代表重复内存增长的代表。Growth#Persistent列告诉你自上一代以来有多少额外内存和多少次分配。如果您的应用程序在执行操作后恢复到原始状态,则不应指望每代都会有增长。
  • 13)单击一代的显示三角形以显示自上一代以来已分配的新对象。
  • 14)寻找持久的对象。如果您确定其中的一个,请单击显示三角形以显示其实例。
  • 15)选择一个对象实例。
  • 16)按下Command-3在检查器的扩展详细信息区域中显示所选实例的堆栈跟踪。该堆栈跟踪提供负责分配实例的方法调用的完整列表。
  • 17)单击扩展详细信息区域中的折叠Collapse按钮以隐藏堆栈跟踪中的系统调用。这可以更轻松地找到您的应用程序的方法。由您的应用进行的调用会以黑色标志,并以用户代码图标开头。
  • 18)双击堆栈跟踪中的方法以在仪器中显示其代码。
  • 19)单击详细信息窗格顶部的Xcode按钮以打开Xcode中的代码进行编辑。
  • 20)确定分配是否有用。如果不是这样,它就废弃了需要解决的内存。

后记

本篇主要讲述了找到废弃的内存,感兴趣的给个赞或者关注~~~~

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

推荐阅读更多精彩内容