Instrument介绍、Xcode源码版本控制的使用

一、Instrument工具介绍与使用

Instrument是性能分析、动态跟踪和分析OS X和iOS代码的测试工具。它是一个灵活的和强大的工具,可以让您追踪程序运行的过程,收集数据,并检查所收集的数据。

界面:

功能:

1.追踪代码中的(甚至是那些难以复制的)问题;

2.分析程序的性能;

3.实现程序的自动化测试;

4.部分实现程序的压力测试;

5.执行系统级别的通用问题追踪调试;

6.使你对程序的内部运行过程更加了解。

常用的Instrument模板:

Leaks(泄漏):一般的措施内存使用情况,检查泄漏的内存,并提供了所有活动的分配和泄漏模块的类对象分配统计信息以及内存地址历史记录;

Allocations(内存分配):跟踪过程的匿名虚拟内存和堆的对象提供类名和可选保留/释放历史;

Time Profiler(时间探查):执行对系统的CPU上运行的进程低负载时间为基础采样。

Activity Monitor(活动监视器):显示器处理的CPU、内存和网络使用情况统计;

Automation(自动化):这个模板执行它模拟用户界面交互为IOS机应用从instrument启动的脚本;

工具界面:

1、这里控制记录过程,点击红色的"记录"按钮可以停止或开始当前正在分析的app(在记录和停止按钮之间切换),暂停键,如你所想,暂停当前正在运行的app。

2、这里是执行计时器(run timer),计时器记录着正在分析的app执行了多长时间、执行了多少次。如果你使用记录控制按钮来停止你的app,然后重启,这将创建一个新的运行记录,同时会显示"Run 2 of 2"。

3、这里被称作路径(track),就你选择的Time Profiler工具而言,因为只有一个工具,所以这里只有一条路径,关于这里显示的图标的详情,一会你就会在接下来的教程中了解更多。

4、这里是详情面板,展示的是你正在使用的工具的主要信息。就现在而言,这里展示的是最"笨重(hottest)"的方法--换句话说,占用CPU时间最长的方法。点击上方的bar会看到Call Tree(左手边的那个)并选中Sample List,然后你会看到数据的不同视图,视图展示了每一个示例。点击其中几个,你会在Extended Detail inspector中看到被捕获的堆栈跟踪。

5、这里是检查器(inspector)面板,一共有三个检查器:record setting(记录设置),display setting(展示设置),还有extends detail(扩展详情)。一会你将了解更多关于这里面的一些选项。

Call Tree各个选项和功能:

Separate by Thread: 每个线程应该分开考虑。只有这样你才能揪出那些大量占用CPU的"重"线程

Invert Call Tree: 从上倒下跟踪堆栈,这意味着你看到的表中的方法,将已从第0帧开始取样,这通常你是想要的,只有这样你才能看到CPU中花费时间最深的方法.也就是说FuncA{FunB{FunC}} 勾选此项后堆栈以C->B-A 把调用层级最深的C显示在最外面

Hide Missing Symbols: 如果dSYM无法找到你的app或者系统框架的话,那么表中看不到方法名只能看到十六进制的数值,如果勾线此项可以隐藏这些符号,便于简化数据

Hide System Libraries: 勾选此项你会显示你app的代码,这是非常有用的. 因为通常你只关心cpu花在自己代码上的时间不是系统上的

Show Obj-C Only: 只显示oc代码 ,如果你的程序是像OpenGl这样的程序,不要勾选侧向因为他有可能是C++的

Flatten Recursion: 递归函数, 每个堆栈跟踪一个条目

Top Functions: 一个函数花费的时间直接在该函数中的总和,以及在函数调用该函数所花费的时间的总时间。因此,如果函数A调用B,那么A的时间报告在A花费的时间加上B.花费的时间,这非常真有用,因为它可以让你每次下到调用堆栈时挑最大的时间数字,归零在你最耗时的方法。

<font color=#FF6347>现介绍下 Leak 工具的使用</font>

Leak 的使用

1.选择Leaks选项

2.选中设备--app,之后点击红点运行.

3.由于Leaks是动态监测,所以我们需要手动操作APP,一边操作,一边观察Leaks的变化,当出现红色叉时,就监测到了内存泄露,点击右上角的暂停按钮,进行暂停检测(也可继续检测,当多个时暂停,一次处理了多个).如图所示:

4.下面就是定位修改了,此时选中有红色叉的Leaks,下面有个"田"字方格,点开,选中Call Tree。

显示如下图界面


5.下面就是最关键的一步,在这个界面的右下角有若干选框,选中Invert Call Tree 和Hide System Libraries,(红圈范围内)显示如下:

6.定位
在详情面板选中显示的若干条中的一条,双击,会自动跳到内存泄露代码处,然后点击右上角 Xcode 图标进行修改。如图所示


二、Xcode上源码版本控制的使用

从 Xcode5 开始引入了使用 git 的一些新特性。它将 git 的各项功能整合到一个菜单中,并提供子菜单来进行软件合并的控制。菜单如下图所示。

其中功能包括创建分支、切换分支、合并分支、提交(Commit)、撤销修改(Discard Changes)、Pull、查看历史。

由于不知道什么原因,无法验证远程仓库的账号和密码。故无法使用Push操作…

1.分支的操作

1.1新建分支

选择 New Branch ,填写所要新建的分支名称,输入完成系统将会自动切换到所新建的分支。

1.2 切换分支

选择 Switch to Branch ,在新窗口可以看到本地和远程所有的分支,选择所要切换的分支(默认不显示当前分支),点击 Switch 即可。

1.3 合并分支

选择 Merge from Branch,选择将要合并的分支,点击 Merge 即可。

2.提交(Commit)

选择 Commit ,可看到如下图所示的窗口界面。左边为项目中状态发生改变的文件,M表示修改,A表示新添加。中间部分为选定文件的当前版本和前一个版本的对比。下面为此处 commit 的描述信息。

3.撤销修改(Discard Changes)

3.1 Discard All Changes

当选择 Discard All Changes 时,可以将撤销当前工程的所有修改。恢复到当前版本最初状态。

3.2 Discard Change in "文件名"

当选中某个文件,可以撤销该文件的所有修改,恢复到当前版本最初状态。

4.Pull 和查看历史

当选择 Pull,可以从远程仓库获取最新内容。

选择 History,可以查看当前工程的版本信息.点击右边的 show xx modified files,可查看修改了哪些文件。


5.Show the Version Editor

选择Xcode工具栏上方的版本控制编辑,可以看到当前版本和之前版本的对比。


若想查看之前某个版本的文件状态,可以切换下方的文件版本进行查看。

右边滚动条的横线为文件所修改的地方。

若想恢复文件到某个版本,先切换到想回复的版本,点击中间的数字,选择 Discard Change 即可。

三、参考

Instruments User Guide
小白学习instrument
如何使用Instruments诊断App(Swift版):起步

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

推荐阅读更多精彩内容

  • 什么是Git? Git是一个开源的分布式版本控制系统,可以有效、高速的处理从很小到非常大的项目版本管理。简而言之,...
    彼蓝阅读 1,847评论 2 4
  • 在应用程序开发过程中,很重要的一部分工作就是如何进行源码的版本控制。当代码出现问题时,我们就需要将代码恢复到原先正...
    小热狗阅读 454评论 0 0
  • “ 不是每一次都会在那里遇见 闪烁着思念的那个十字路口大街 期待能遇见 你转身 惊鸿一瞥 却只留给我背影 算是成...
    林深时见鹿嘛阅读 169评论 0 0
  • 作者:贞子 美国《读者文摘》继那年“丢”钱包之后,前不久,又在全球32个城市“丢”下了960部手机。之后情况是什么...
    worldhello阅读 676评论 0 1
  • 一直很喜欢用手机的微距功能拍摄花花草草,近距离地观察植物的世界。 想当日,天气晴朗,夕阳当照。 我下班从公司走回宿...
    1厘米8光年阅读 484评论 2 6