Xcode里的Instruments工具:Leaks、Alloc

作者: Python数据分析实战 | 来源:发表于2016-03-24 18:09 被阅读3181次
    屏幕快照 2016-03-24 11.45.28.png

    一、Leaks: 内存泄露检测工具

    1、静态检测内存泄露Analyze

    屏幕快照 2016-03-24 11.21.54.png

    点击后显示如图,然后点击上面的


    A794C733-3CBE-419B-93E9-292F139CDFD2.png

    a、点击1查看左测,进行定位
    b、点击2进行准确定位
    c、查看错误泄露原因

    2、动态监测 Instruments的Leaks

    屏幕快照 2016-03-24 11.42.59.png

    选择工具,点击图中的Profile或快捷键:


    E41F6D4C-30DC-40B3-B9CA-D0C8E97CD2C3.png

    command+i
    弹出Instruments工具箱,选择Leaks

    屏幕快照 2016-03-24 11.45.14.png

    显示如图,并按下键盘:command+R 运行app,此时手动操作app查看内存泄露

    93A23670-BA58-4DFE-B7FB-5EAB7077CA69.png 4D5B7953-EFBA-49B6-9D05-C223452CBB78.png

    当操作app过程中,发现有红的小叉,就说明有内存泄露,接下来的目的就是找到泄露位置并修复
    a、点击1处按钮,暂停检测,
    b、点击2转到leaks下(此步骤感觉可有可无)
    c、将鼠标放到3处可查看泄露个数
    d、将1的选框选为Call Tree
    e、将右侧2的选择调至中间
    f、对Call Tree进行限制,将3打上勾
    g、看4如果后面有箭头则展开,直到出现类似5的(后面没箭头),然后双击5,它就会跳到内存泄露处,修复即可

    屏幕快照 2016-03-24 13.01.35.png

    二、 Time Profiler:分析代码的执行时间,找出导致程序变慢的原因

    a、调出Instruments工具操作同Leaks,不做复述,然后选择 Time Profiler,弹出界面,然后使用快捷键command+R,启动 Time Profiler 和 app,并操作app,查看执行时间

    E41F6D4C-30DC-40B3-B9CA-D0C8E97CD2C3.png

    虽然代码没什么可优化的地方,但大家应该认识到缓存能发挥的作用。对于经常访问的页面,多数情况下把图片缓存下来,还是能省些资源占用。

    Separate by Thread:按线程分开做分析,这样更容易揪出那些吃资源的问题线程。特别是对于主线程,它要处理和渲染所有的接口数据,一旦受到阻塞,程序必然卡顿或停止响应。
    Invert Call Tree:反向输出调用树。把调用层级最深的方法显示在最上面,更容易找到最耗时的操作。
    Hide System Libraries:隐藏系统库文件。过滤掉各种系统调用,只显示自己的代码调用。
    Flattern Recursion:拼合递归。将同一递归函数产生的多条堆栈(因为递归函数会调用自己)合并为一条。
    Top Functions:找到最耗时的函数或方法。
    b、个人感觉选两个就够啦,有选前四个的,可能更全面,有需要的自己打上勾就ok拉
    c、选择其中一个双击,就会跳转到对应的代码页,如图

    屏幕快照 2016-03-24 16.40.21.png

    三、 Allocations:监测内存使用/分配情况

    a、调出Instruments工具操作同Leaks,不做复述,然后选择 Allocations,弹出界面,然后使用快捷键command+R,启动 Allocations 和 app,并操作app,查看某个方法所占用的内存,然后双击进入详情,这里不做复述

    559C0051-62A6-4D87-B24E-1B3FF2A572DB.png

    四、 Automation:自动化测试,类似于Android的Monkey

    a、调出Instruments工具操作同Leaks,不做复述,然后选择 Automation,弹出界面


    61D49467-5391-4643-8ABB-4FB26A0DD889.png

    如图所标:
    1为脚本区,2为控制区
    b、此时应该先录制操作脚本,点击2,同时它会自动为你运行app,你只需要打开你的模拟器,然后操作app,脚本会自动记录下你的操作步骤,


    屏幕快照 2016-03-24 17.18.19.png

    c、进行相关设置,设置好以后点击左上角开始运行脚本


    5363DE25-29E1-4E11-A587-4B434204D2C3.png

    d、查看操作,说明如下


    B4DE3291-CB70-4DA0-A646-31DE7B118017.png
    1处是脚本运行和开关
    2处可以查看运行状态,双击可在脚本与记录之间切换,如果操作出错,此处会变黄,双击即可找到错误操作处

    3处为操作日志或记录

    写这么多,但愿能对大家有一点点帮助,如有不对,希望指正

    相关文章

      网友评论

      • a67e02faf22f:Xcode功能强大,但是不会用= =真的是个问题
      • plantseeds:我检查的内存泄漏,好几个 点进去都跳到AFNetWorking库的代码中去了,请问啥原因呀,感觉不应该是AFNetWorking有内训泄露呀😂
      • OCSwift:收藏了
      • fe86d48aad87:谢谢你,对我帮助很大 :grin:
      • Trouble_Maker:新技能get:grin:
      • Gwinds:还有没有其他的优化工具
      • f17b24f4d7bc:不错。。。果断收藏
      • jingijtk:可以
      • 常义:学习了
      • 咖啡凯:👏🏻
      • 小明是大叔:刚把run调到release版本,就显示main数出错,几千个,是什么原因啊,这也没法定位啊,话说已经顺利上架两个版本了
      • 小明是大叔:请教一下,出现泄漏了,但是却无法定位到代码,双击后显示unavailable,是什么原因,静态分析是没有泄漏的
      • 以技术之名:你好,我想问一下,检测内存泄露的时候为什么无法选择真机?其他的没试过
        以技术之名:@SilenceYaung 原来的时候试过不行,今天不知道怎么就可以啦😜😜😜
        以技术之名:@SilenceYaung 真机是可以的,我试过了

      本文标题:Xcode里的Instruments工具:Leaks、Alloc

      本文链接:https://www.haomeiwen.com/subject/wcrrlttx.html