由于Xcode调试工具Instruments指南篇幅太长,所以本篇blog继续上篇,介绍对Instruments收集到的数据去分析。

关于数据分析

Instruments不解决你代码中的任何问题,它帮助你更好的理解你的代码正在做什么,通过捕获你app运行的详细统计数据,并呈现它们給你去分析。由于每个app是不同的,发现和解决问题的实际步骤有所不同。因此你必须了解怎样解释那些你筛选后Instruments收集的数据。并探讨与你app有关的数据,你必须执行一些工作,标识代码中的数据在app中,这样你就可以做出改进。

执行跟踪后,你可以时间窗口中,想求窗口,指示窗口的详情区域查看所收集的数据


查看时间线窗口

一个追踪文件最重要的部分为时间线窗口,介绍了由每个工具基于时间收集的数据视图。这个窗口可以很容易的发现趋势和潜在问题的区域在你的app中。例如,一个内存使用图标的尖峰表示你的app比平时分配更多的内存。这个尖峰可能是正常的,也可能表示你代码中创建了大量的对象,或者内存的缓冲区超出你的预期。一个工具,例如Leaks可以验证你的app没有正常的处理内存如果Leaks的时间线窗口追踪是稀疏的填充,你知道你的app是正确的行为,如果追踪不为空你可能要检查原因。

一下各节提供有关时间线窗口的信息,以及如何配置它。

放大和缩小

如果你已经在追踪中捕获了大量的数据,你可以扩大或者缩小在时间线窗口中显示的细节,让你更专注在指定的数据上。

放大和缩小数据

请执行下列操作之一:

  • 要放大或缩小,捏合触控板
  • 要放大或缩小,使用滚轮的同时按下Option键将光标定位在轨迹视图。
  • 要放大,按Option键,然后拖动隔离选中的数据
  • 要缩小,按Ctrl键,然后拖动选中的数据。

在时间线窗口记录所有合适的数据

请执行下列操作之一:

  • 按 Command-Control-Z

在时间线窗口中增加数据显示的尺寸

请执行下列操作之一:

  • 按Command-Plus (+)

    这个轨迹增加当前选中工具的高度,允许你查看它更多的细节。

在时间线窗口中减少数据显示的尺寸

请执行下列操作之一:

  • 按Command-Minus (-)

过滤数据的范围

Instruments收集大量的信息作为它的配置文件,你可以快速的过滤这些数据通过设置详情窗口,展示特定时间范围内发生的唯一的事件。

选择一个时间段进行检查

1.拖动数据的一部分,不使用任何按键,只有你拖动数据显示。



你指定的范围在时间线窗口高亮的内容。

清除检查范围

请执行下列操作之一:

  • 点击时间线选中范围的外面

设置标示

标示可以让你在时间线窗口中快速访问感兴趣的点,你可以为每个标志添加名字和描述。

在当前时间线窗口的播放指示器设置一个标示

请执行下列操作之一:

  • 按Command–Down Arrow

在你时间线标示中查看

1.

2.在标示中点击一个标示然后在时间线面板中查看

删除一个标示

把标示拖拽出时间线导航栏

隐藏一个标示

1.

2.

访问多个运行的追踪数据

一个追踪文件可以在你的app运行过程中记录多个数据,当这样做时不会丢弃先前记录的数据

查看一个选中工具的运行列表

该工具展开以显示运行的列表

查看一个选中工具的运行数据

1.

2.在时间线窗口中选择所需的运行轨迹

移动到下一个选中工具的运行

请执行下列操作之一:

    • 按Command-Apostrophe (‘)

    移动到上一个选中工具的运行

    请执行下列操作之一:

  • 按 Command-Quotation (“)


查看详情窗口

当你在时间线窗口辨认出一个潜在问题区域,使用详情窗口在这个区域检查数据,这个详情窗口显示与所选择的工具当前追踪运行的相关数据,Instruments在详情窗口只显示一段时间的一个工具。因此你必须选择不同的工具来开不同组的信息。

打开或者关闭详情面板

请执行下列操作之一:

  • 在工具栏的右端点击

在详情窗口查看指定工具的数据

1.

在详情窗口中查看不同种类的数据

对于某些工具你可以显示一个以上格式的数据,例如Activity Monitor允许你查看数据的汇总,父子信息与采样列表。

在详情种类切换

工具的模式支持取决于工具收集数据的种类

对于一些详情的种类,像Allocations可以调用树模式,你可以使用展开一个特定的行,进一步分解成相应的层次,点击一个三角形展开或者关闭一个给定的行。

在详情窗口排序

根据特定的列的数据在详情窗口排序信息显示。请点击相应的列的页眉,在每个工具在详情窗口中的列不同。

使用扩展详情窗口

对于一些工具,在指示窗口扩展详情的区域展示有关当前在详细信息窗格中选择项目的附加信息,这个扩展的详细信息可包括探针描述或被记录的时间,栈追踪,和当记录信息的时间,以及其他信息。

打开或者关闭指示窗口的扩展详情区域

请执行下列操作之一:

  • 按Command-2

  • 点击按钮

您可以通过单击折叠按钮隐藏在堆栈跟踪系统调用


查看app的源代码

如果你有一个Xcode项目在栈追踪符号列表的源代码,Instruments可以显示你的代码,并可以在Xcode中打开,这样就可以做出任何期望的改变。

使用栈追踪符号找到你写的源代码,用户端啊栈追踪符号出现在详情窗口与黑色背景上的小方块用户图标,为了更方便的找到符号代码,你可以实现使用显示设置区域在指示器窗口筛选出隐藏符号和系统库。

查看app的源代码

1.

2.双击



3.点击在详情窗口的右上角打开Xcode,并显示你的源代码,下面截图显示出现在详情窗口顶部的Xcode按钮的位置。它出现后你双击符号或详情窗口或指示窗口中扩展的详情区域中的图标显示在详细信息窗格中的代码。

Instruments-查看收集到的数据的更多相关文章

  1. ELKF-分布式日志收集分析平台搭建 最小化 配置过程 - 查看收集日志(windows10下搭建)

    前言 Elasticsearch是与名为Logstash的数据收集和日志解析引擎以及名为Kibana的分析和可视化平台一起开发的.这三个产品被设计成一个集成解决方案,称为“Elastic Stack” ...

  2. MVC5 + EF6 + Bootstrap3 (13) 查看详情、编辑数据、删除数据

    Slark.NET-博客园 http://www.cnblogs.com/slark/p/mvc5-ef6-bs3-get-started-rud.html 系列教程:MVC5 + EF6 + Boo ...

  3. 查看被锁的数据[Z]

    SELECT LOCK_INFO.OWNER || '.' || LOCK_INFO.OBJ_NAME AS OBJ_NAME --对象名称(已经被锁住) ,LOCK_INFO.SUBOBJ_NAME ...

  4. T-SQL技术收集——删除重复数据

    原文:T-SQL技术收集--删除重复数据 在工作和面试中,经常出现如何查询或者删除重复数据的问题,如果有主键,那还好办一点,如果没有主键,那就有点麻烦. 当一个表上没有辅助键时,如果使用SSMS界面来 ...

  5. Linux下,如何查看磁盘是否包含数据

    可以使用lquerypv -h来查看磁盘是否包含数据,或磁盘头是否被dd过.这在安装RAC的过程中,是非常实用的一个命令.如果不包括数据的话,那么如下所示: [ZFFR4CB2101:root]/]& ...

  6. TCP/IP 笔记 6 netstat -s 命令查看每个协议统计数据

    netstat -s 命令,查看每个协议统计数据的常用方法 lenovo-myc@lenovomyc-Lenovo-Product:~$ netstat -s Ip: total packets re ...

  7. 【ABAP系列】SAP ABAP如何在调试查看EXPORT/IMPORT 内存数据

    公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[ABAP系列]SAP ABAP如何在调试查看E ...

  8. 实现页面查看xml或json数据类似控制台效果

    在前端查看xml或者json数据时,实现在类似与控制台中console的效果. 配合Ant Design的Collapse折叠面板进行展示. Collapse组件的地址:https://ant.des ...

  9. 通过dbcc page来查看表中的数据

    --1.先建表 CREATE TABLE test(idd INT NOT NULL,name VARCHAR(10) NULL) INSERT INTO TEST SELECT 1,'abcdefg ...

随机推荐

  1. 数据缓存iOS

    有时候,对同一个URL请求多次,返回的数据可能都是一样的,比如服务器上的某张图片,无论下载多少次,返回的数据都是一样的. 上面的情况会造成以下问题 (1)用户流量的浪费(2)程序响应速度不够快 解决上 ...

  2. iOS10.0 TabBar Bug(底部同时展示原生和自定义tabBar)-b

    在没有发布iOS10的时候,在任何模拟器测试下效果正常,更新iOS10后,测试出现BUG先放一张bug之前的效果图: 修改前出现的bug 在检查了所有问题之后,最后把问题定位在了原生系统tabBar底 ...

  3. android 开发解密时出现pad block corrupted 错误

    情景:在虚拟机上运行正常的,但是到我的真机上就解密失败,出现pad block corrupted  ,据说是版本原因:我机器是小米3 最新版的android  4.2 出现问题的代码: privat ...

  4. Java7 新特性 switch 可以使用String

    今天和大家分享下 在java7中可以使用String 作为switch 中的参数. 原来在java7之前,switch只能去接收一个 byte.char.short.int 类型 现在在java7中 ...

  5. C#textbox右击弹出菜单

    给窗口体拖一个contextMenuTrip 控件,也就是右键菜单控件,这时你就不要给这个控件写内容了, 选中textBox 然后点属性窗口,把它的contextMenuTrip 属性选中你刚才托的那 ...

  6. 解决jquery版本冲突问题

    解决jQuery1.3.2和1.4.2的冲突.(测试通过) 第一步:在1.4.2的源代码的最后加上一句 var $j4 = jQuery.noConflict(true);//之所以在源码这里加,而不 ...

  7. 飞信免费发送接口API的测试 httpClient

    测试飞信免费发送接口API的测试(HTTPClient实现) 使用优点:快捷,方便 使用缺点:用户的各种信息以明文形式在网络中传输不安全. 仅仅用于测试 package cn.com.vnvtrip. ...

  8. CentOS下安装Redmine 2.5.2

    Redmine是用Ruby开发的基于web的项目管理软件,所以先要下载安装Ruby,再下载对 Ruby组件进行打包的 Ruby 打包系统RubyGems. 第一步:下载必要的软件 1.依赖包安装 # ...

  9. hdu 1575 Tr A(矩阵快速幂,简单)

    题目 和 LightOj 1096 - nth Term  类似的线构造一个符合题意的矩阵乘法模版,然后套快速幂的模版,具体的构造矩阵我就不作图了,看着代码也能理解吧 #include<stdi ...

  10. Linux shell 脚本小记

    if结构 #!/bin/env bash -gt ] then echo "$1 is positive" -lt ] then echo "$1 is negative ...