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)届谈。如圖:
點(diǎn)擊進(jìn)入Leaks的主面板枯夜。如圖:
1:錄制按鈕
2:暫停按鈕
3:內(nèi)存分配
4:內(nèi)存泄漏
5:詳細(xì)信息的查看方式
點(diǎn)擊紅色按鈕開(kāi)始錄制。如圖:
開(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)。如圖:
- 點(diǎn)擊進(jìn)入和Leaks類(lèi)似的界面氨距,同樣點(diǎn)擊底部的Call Tree 選中Invert Call Tree 和 Hide Systerm Libraries桑逝,原因同上。界面如圖:
- 開(kāi)始錄制俏让,在手機(jī)上操作具體想要測(cè)試的頁(yè)面楞遏,Instagrams就會(huì)顯示出所有調(diào)用的函數(shù)以及該函數(shù)運(yùn)行的時(shí)間等等。如圖:
- 正常情況下紅色框圈住的地方應(yīng)該是顯示具體的函數(shù)名稱(chēng)首昔,治理之所以沒(méi)顯示出來(lái)是因?yàn)镈SYM文件沒(méi)有加載上寡喝,有可能和設(shè)置有關(guān),可嘗試進(jìn)行如下設(shè)置(選DWARF with dSYM File):
所有的Instruments模塊使用中如果只出現(xiàn)函數(shù)地址勒奇,不出現(xiàn)函數(shù)名的情況 都可以嘗試如上方法
一切設(shè)置正常后预鬓,進(jìn)入Times profiler就是如圖的界面:
- 接下來(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è)幾乎一致珊皿,如圖:
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后主界面如圖:
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)擊如圖所指:
接下來(lái)會(huì)進(jìn)入內(nèi)存圖:
點(diǎn)擊左側(cè)紫色的感嘆號(hào)郑原,就會(huì)顯示具體的內(nèi)存引用圖:
可以明顯看到有環(huán)產(chǎn)生,造成了內(nèi)存泄漏夜涕,根據(jù)自己代碼情況進(jìn)行修改犯犁。