专栏首页Python疯子Xcode里的Instruments工具:Leaks、Allocations、Time Profiler、Automation

Xcode里的Instruments工具:Leaks、Allocations、Time Profiler、Automation

屏幕快照 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处为操作日志或记录

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • SQL中GROUP BY用法示例

    GROUP BY我们可以先从字面上来理解,GROUP表示分组,BY后面写字段名,就表示根据哪个字段进行分组,如果有用Excel比较多的话,GROUP BY比较类...

    Awesome_Tang
  • 儿童创造力教育与编程教育的碰撞——MIT雷斯尼克教授最新理论梗概

    儿童编程教育已经在我国各一线二线城市疯狂出现,颇有“烂大街”的趋势。我们不禁要问很多很多问题:

    一石匠人
  • 《动物魔法学校》儿童学编程Scratch之“外观”部分

    导读:本文通过一个案例《动物魔法学校》来学习Scratch语言的“外观”部分。之后通过一系列其他功能的综合运用对作品功能进行了扩展。

    一石匠人
  • 【系统设置】CentOS 修改机器名

    ken.io
  • 声音功能让儿童编程更有创造性

    导读:Scratch中声音功能非常强大,除了常规的音效,你甚至可以模拟各种乐器的各个发音、设置节拍、休止……如果你愿意,甚至可以用它创作一个交响乐。我们可以引导...

    一石匠人
  • 复杂业务下向Mysql导入30万条数据代码优化的踩坑记录

    从毕业到现在第一次接触到超过30万条数据导入MySQL的场景(有点low),就是在顺丰公司接入我司EMM产品时需要将AD中的员工数据导入MySQL中,因此楼主负...

    haifeiWu
  • 一张图理清《梅花易数》梗概

    学《易经》的目的不一定是为了卜卦,但是了解卜卦绝对能够让你更好地了解易学。今天用一张思维导图对《梅花易数》的主要内容进行概括,希望能够给学友们提供帮助。

    一石匠人
  • 什么样的人生才是有意义的人生——没有标准的标准答案

    【导读】其实我们可以跳出这个小圈圈去更加科客观地看一下这个世界。在夜晚的时候我们仰望天空,浩瀚的宇宙中整个地球只是一粒浮尘,何况地球上一个小小的人类?在漫长的历...

    一石匠人
  • 我不是算命先生,却对占卜有了疑惑——如何论证“占卜前提”的正确与否

    事出有因,我对《周易》感兴趣了很多年。只是觉得特别有趣,断断续续学习了一些皮毛。这几天又偶然接触到了《梅花易数》,觉得很是精彩,将五行八卦天干地支都串联了起来。...

    一石匠人
  • 天干地支五行八卦的对应关系

    一石匠人

扫码关注云+社区

领取腾讯云代金券