天天看點

iOS 調試工具

  • 儀表

   xcode5 引入了調試儀表,通過儀表可以直覺的看出應用的CPU和記憶體占用量。運作一個程式,點選儀表欄。可以發現當程式處于運作狀态時,調試導航面闆會以柱狀圖顯示CPU和記憶體占用量,并随着應用實時更新占用量資料。需要注意的是,調試導航面闆中的資料是根據應用的硬體計算出來的,蘋果電腦的CPU比iOS裝置更快,如果在iOS模拟器上運作應用,調試導航面闆中顯示的CPU贊用量可能非常低,不低于分析性能問題。

iOS 調試工具

  點選CPU可以在編輯區域打開CPU占用量報告。

iOS 調試工具
  •   占用百分比(Precentage Utilized)

  根據運作應用裝置的CPU核心數顯示CPU占用比。例如,單核裝置中最大CPU占用量是100%,而對雙核裝置中是200%,是以應用在單核裝置中的CPU占用量通常比雙核裝置更高。如果應用處于空閑狀态(進入背景活沒有操作),CPU占用量會顯示0%。

  •   占用環比(Utilization Comparison)

  使用環比圖比較應用與系統中其他程序(Process)的CPU占用百分比。如果應用的CPU占用百分環比不高,但是運作不通暢,那麼可以從該環形圖中檢視Other Processes的占用百分比。如果裝置中背景運作的其他應用太多 ,就可能導緻Other Processes的占用百分比很高,應用運作速度變慢。

  •   時間-占用比(Utilization over Time)

  使用折線圖顯示應用CPU占用量随運作時間變化的過程,以及占用量在運作時間内的峰值和谷值。

  •   線程(Threads)

  顯示應用中每一個線程的時間-占用比。

  

  接下來我們打開我們應用 JXTouchTracker ,用手指在應用中繪制線條,手指不要離開螢幕,持續繪制大量線條可以發現應用的CPU占用比迅速升高-手指在螢幕上移動時,JXDrawView會不斷收到 touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event 消息并調用 drawRect:(CGRect)rect 重繪自己。繪制的線條越多, drawRect:(CGRect)rect 的工作量就越大,CPU占用比就越高。

  回到吊事導航面闆,點選Memory,打開記憶體占用量報告,如圖:

iOS 調試工具

  和CPU占用量報告類似,記憶體占用量報告直接的顯示了應用記憶體占用的情況,但是Memery部分(位于最下方)顯示的折線圖可能會讓我們誤解:應用似乎始終占用了100%的記憶體。實際上,途中将運作時間内的占用峰值作為100%顯示,是以途中y周的最大值與左側High欄中顯示的數值相同都是58.2MB。

  無論開發何種類型的應用,都應該盡可能降低CPU和記憶體占用量,提高應用的流暢度和使用者體驗。

  • Instruments

  從儀表和占用量報告中可以簡要分析出應用的性能,但是,如果應用的CPU和記憶體占用量過高,需要從代碼中查找性能問題,則可以使用 Instruments ,他提供了比儀表和占用量報告更詳細的資料分析。

   Instruments 是一中與Xcode緊密內建的調試工具,可以實時監控并統計應用運作時的各項資料,生成詳細的分析報告。它由若幹元件組成,這些元件檢查的事項包括:應用建立了那些對象,每一個方法和函數的CPU占用量、檔案I/O和網絡I/O等。通過使用這些不同的元件,可以找出程式中的性能瓶頸,發現代碼中的問題。

  •  Allocations 元件

   Allocations 元件可以列出應用建立過的全部對此昂,以及這些對象所占用的記憶體大小。

  當監視某個應用時, Allocations 元件會對這個應用進行性能分析。雖然可以在模拟器上對某個應用進行性能分析,但是在真是的裝置上進行可以得到更精确的資料。

  要對目前打開的項目執行性能分析,可以按住位于坐上角的 Run 按鈕不放,然後在新出現的彈出視窗中選擇 Profile 。

iOS 調試工具

  Xcode會啟動 Instruments 。 Instruments 會顯示一個下拉視窗并列出所有可用的元件。選中 Allocations 。之後 Instruments 會啟動應用并打開 Instruments 的主視窗。

iOS 調試工具
iOS 調試工具

   Allocations 元件會顯示一張表格,流出應用 執行過的所有記憶體配置設定。因為資料比較多,是以先過濾,隻列出由我們自己編寫的代碼建立的對象。首先在JXDrawView對象上畫若幹線條。然後在視窗 Category 查詢框中輸入 JXLine 。

   Allocations 元件會過濾  Object Summary 表格所顯示的條目,隻列出和 JXLine 右端的記憶體配置設定,即我們自己建立的 JXLine 對象。

iOS 調試工具

   #Persistent 列會顯示某種對象的現存個數。 Persistent Bytes 列會顯示這些現存對象占用了多少記憶體。 # Total 列會顯示應用運作至今共建立了多少個某種類型的對象(其中包括已經釋放的對象)。

繼續閱讀