Xcode 8 最新版Instruments的使用教程

Instruments的介紹

Instruments 一個(gè)很靈活的盲赊、強(qiáng)大的工具,是性能分析、動(dòng)態(tài)跟蹤 和分析OS X以及iOS代碼的測(cè)試工具谋国,用它可以極為方便收集關(guān)于一個(gè)或多個(gè)系統(tǒng)進(jìn)程的性能和行為的數(shù)據(jù)葵礼,并能及時(shí)隨著時(shí)間跟蹤而產(chǎn)生的數(shù)據(jù)号阿,并檢查所收集的數(shù)據(jù),還可以廣泛收集不同類(lèi)型的數(shù)據(jù).也可以追蹤程序運(yùn)行的過(guò)程鸳粉,這樣instrument就可以幫助我們了解用戶(hù)的應(yīng)用程序和操作系統(tǒng)的行為扔涧。

常用模塊

Leaks :找到引發(fā)內(nèi)存泄漏的起點(diǎn)

啟動(dòng)Instruments,找到Leaks圖標(biāo)届谈。如圖:

leaks.png

點(diǎn)擊進(jìn)入Leaks的主面板枯夜。如圖:

leaks1.png

1:錄制按鈕

2:暫停按鈕

3:內(nèi)存分配

4:內(nèi)存泄漏

5:詳細(xì)信息的查看方式

點(diǎn)擊紅色按鈕開(kāi)始錄制。如圖:

leaks3.png

開(kāi)始錄制后可以發(fā)發(fā)現(xiàn)leaks一欄有紅色的差出現(xiàn)疼约,代表出現(xiàn)了內(nèi)存泄漏卤档。

點(diǎn)擊箭頭1所指的地方,選取Call Tree 程剥,接下來(lái)箭頭2所指的地方會(huì)出現(xiàn)四個(gè)選項(xiàng)劝枣。
Snapshots選項(xiàng)是設(shè)置時(shí)間間隔的,推薦設(shè)置成10.

Call Tree選項(xiàng)點(diǎn)擊后會(huì)出現(xiàn)四個(gè)菜單织鲸,推薦勾選Invert Call Tree(方便快速定位調(diào)用棧)和Hide Systerm Libraries(過(guò)濾掉一些無(wú)用的系統(tǒng)信息)舔腾。

雙擊中間顯示的調(diào)用函數(shù)行,可以定位到自己所寫(xiě)得代碼搂擦。

在運(yùn)行的過(guò)程中可以發(fā)現(xiàn)泄漏就暫停稳诚,然后拖動(dòng)時(shí)間軸到泄漏的附近,就可以?xún)H查看該泄漏的函數(shù)調(diào)用棧瀑踢。

?

Time Profiler : 分析代碼的執(zhí)行時(shí)間扳还,找出導(dǎo)致程序變慢的原因

  • 啟動(dòng)Instruments才避,找到Leaks圖標(biāo)。如圖:
time.png
  • 點(diǎn)擊進(jìn)入和Leaks類(lèi)似的界面氨距,同樣點(diǎn)擊底部的Call Tree 選中Invert Call Tree 和 Hide Systerm Libraries桑逝,原因同上。界面如圖:
time1.png
  • 開(kāi)始錄制俏让,在手機(jī)上操作具體想要測(cè)試的頁(yè)面楞遏,Instagrams就會(huì)顯示出所有調(diào)用的函數(shù)以及該函數(shù)運(yùn)行的時(shí)間等等。如圖:
time2.png
  • 正常情況下紅色框圈住的地方應(yīng)該是顯示具體的函數(shù)名稱(chēng)首昔,治理之所以沒(méi)顯示出來(lái)是因?yàn)镈SYM文件沒(méi)有加載上寡喝,有可能和設(shè)置有關(guān),可嘗試進(jìn)行如下設(shè)置(選DWARF with dSYM File):
dsym.png
  • 所有的Instruments模塊使用中如果只出現(xiàn)函數(shù)地址勒奇,不出現(xiàn)函數(shù)名的情況 都可以嘗試如上方法

  • 一切設(shè)置正常后预鬓,進(jìn)入Times profiler就是如圖的界面:

time3.png
  • 接下來(lái)就是查找哪些函數(shù)比較耗時(shí)根據(jù)情況進(jìn)行優(yōu)化
  • 雙擊對(duì)應(yīng)的函數(shù)或者點(diǎn)擊后面的小箭頭就會(huì)進(jìn)入自己寫(xiě)的代碼處,方便分析代碼撬陵。

Core Animation :幀率檢測(cè)

Core Animation的基本使用方法和以上連個(gè)幾乎一致珊皿,如圖:

animation.png

Frame Per second一欄就是當(dāng)前頁(yè)面的幀率,到達(dá)60說(shuō)明很流暢巨税。檢測(cè)幀率的過(guò)程中正確的姿勢(shì)是手指不要離開(kāi)屏幕蟋定。

對(duì)于幀率檢測(cè),推薦一款小工具——KMCGeigerCounter草添,該工具可以在頁(yè)面頂部實(shí)時(shí)顯示當(dāng)前頁(yè)面滑動(dòng)時(shí)的幀率(用的時(shí)候需要修改一處window以前的錯(cuò)誤)驶兜;

Allocations

進(jìn)入Allocations后主界面如圖:

1440398-d68d941aa032c25b.png

1.堆區(qū)內(nèi)存和虛擬內(nèi)存占用圖

2.堆區(qū)內(nèi)存占用圖

3.虛擬內(nèi)存跟蹤圖

4.選擇使用不同的形式展示內(nèi)存占用情況

5.勾選讓上面曲線(xiàn)圖展示對(duì)應(yīng)內(nèi)存占用情況

6.持久分配的內(nèi)存所占字節(jié)數(shù)(未釋放)即該類(lèi)對(duì)象在內(nèi)存中占得總內(nèi)存

7.持久創(chuàng)建的對(duì)象個(gè)數(shù)(未釋放)即該對(duì)象存在于內(nèi)存中的個(gè)數(shù)

8.臨時(shí)分配的對(duì)象個(gè)數(shù)(未釋放)即存在過(guò)已經(jīng)被回收的對(duì)象的個(gè)數(shù)

9.分配的所有內(nèi)存所占字節(jié)數(shù)(未釋放)

10.創(chuàng)建的對(duì)象總數(shù)(未釋放)

11.設(shè)置面板,不同的設(shè)置使左邊有不同展示效果

Cocoa Layout

網(wǎng)上關(guān)于Cocoa Laout的文章介紹比較少远寸,僅僅找到老外老早之前寫(xiě)的一篇文章抄淑,可以參考著看下。
https://www.bignerdranch.com/blog/inpecting-auto-layout-with-the-cocoa-layout-instrument/

注意只能在模擬器上測(cè)試驰后,不支持真機(jī)肆资。

Xcode 8 Memory Graph

Xcode8的調(diào)試技能又增加了一個(gè)黑科技:Memory Graph。簡(jiǎn)單的說(shuō)就是可以在運(yùn)行時(shí)將內(nèi)存中的對(duì)象生成一張圖.
運(yùn)行項(xiàng)目(demo地址)灶芝,點(diǎn)擊如圖所指:

memory2.png

接下來(lái)會(huì)進(jìn)入內(nèi)存圖:

memory3.png

點(diǎn)擊左側(cè)紫色的感嘆號(hào)郑原,就會(huì)顯示具體的內(nèi)存引用圖:

memory.png

可以明顯看到有環(huán)產(chǎn)生,造成了內(nèi)存泄漏夜涕,根據(jù)自己代碼情況進(jìn)行修改犯犁。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市女器,隨后出現(xiàn)的幾起案子酸役,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,755評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件涣澡,死亡現(xiàn)場(chǎng)離奇詭異贱呐,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)暑塑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,305評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)吼句,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人事格,你說(shuō)我怎么就攤上這事「阋” “怎么了驹愚?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,138評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)劣纲。 經(jīng)常有香客問(wèn)我逢捺,道長(zhǎng),這世上最難降的妖魔是什么癞季? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,791評(píng)論 1 295
  • 正文 為了忘掉前任劫瞳,我火速辦了婚禮,結(jié)果婚禮上绷柒,老公的妹妹穿的比我還像新娘志于。我一直安慰自己,他們只是感情好废睦,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,794評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布伺绽。 她就那樣靜靜地躺著,像睡著了一般嗜湃。 火紅的嫁衣襯著肌膚如雪奈应。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,631評(píng)論 1 305
  • 那天购披,我揣著相機(jī)與錄音杖挣,去河邊找鬼。 笑死刚陡,一個(gè)胖子當(dāng)著我的面吹牛惩妇,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播橘荠,決...
    沈念sama閱讀 40,362評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼屿附,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了哥童?” 一聲冷哼從身側(cè)響起挺份,我...
    開(kāi)封第一講書(shū)人閱讀 39,264評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎贮懈,沒(méi)想到半個(gè)月后匀泊,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體优训,經(jīng)...
    沈念sama閱讀 45,724評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,900評(píng)論 3 336
  • 正文 我和宋清朗相戀三年各聘,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了揣非。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,040評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡躲因,死狀恐怖早敬,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情大脉,我是刑警寧澤搞监,帶...
    沈念sama閱讀 35,742評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站镰矿,受9級(jí)特大地震影響琐驴,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜秤标,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,364評(píng)論 3 330
  • 文/蒙蒙 一绝淡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧苍姜,春花似錦牢酵、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,944評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至屈嗤,卻和暖如春潘拨,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背饶号。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,060評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工铁追, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人茫船。 一個(gè)月前我還...
    沈念sama閱讀 48,247評(píng)論 3 371
  • 正文 我出身青樓琅束,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親算谈。 傳聞我的和親對(duì)象是個(gè)殘疾皇子涩禀,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,979評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容