专栏首页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 条评论
登录 后参与评论

相关文章

  • Swift-第一个程序_网页展示

    b、左边选择IOS中的Application,右边Singl View Application,最后next

    Python疯子
  • 阿拉伯数字转中文大写,金额转中文大写

    金额转换是因为自己需要从网上找的demo,这两个功能按需求改的,所以代码大致相同,就粘贴一份​代码:

    Python疯子
  • 数据库怎么存储手机号,QQ等纯数字内容,最省内存

    Python疯子
  • 四个好用却可能不为人所知的Numpy函数,建议收藏!!

    今天,小编就和大家来说说,在numpy库中也存在着不少好用却也不为人所熟知的函数,建议收藏!!

    用户6888863
  • 类数组借用数组方法

    于JavaScript如何将对象转化为数组对象,其用法写法已经很常见且完善,比如JQuery中的makeArray函数对此的实现,也是跟大家想的差不多,只是考虑...

    晚晴幽草轩轩主
  • JIRA笔记(一):安装部署JIRA

    free赖权华
  • Typora:极致简洁的markdown编辑器

    一个会写诗的程序员
  • SAP Fiori Launchpad Tile,UI5应用,和PFCG Role的对应关系

    问题:已经看到了SAP Fiori Launchpad上的某个tile,如何反推后台需要配置哪个PFCG Role才能看到该tile?

    Jerry Wang
  • 【战“疫”背后】:这个春节,他们重新定义了远程工作

    ? 作者:ritayuan,转自:《科技云端》 1 月 23 日,武汉封城,“新冠”病毒犹如当头一棒敲进喜气洋洋的春节假期;两天后的大年初一,企业 IT ...

    腾讯技术工程官方号
  • Snova架构篇(二):Greenplum核心组件

    当PostgreSQL的后台进程Postgres接收到查询语句后,首先将其传递给查询分析模块,进行词法、语法和语义分析。若是功能性命令(例如建表、创建用户、备份...

    snova-最佳实践

扫码关注云+社区

领取腾讯云代金券