DDMS 與 TraceView


DDMS 可用於  檢測內存泄漏;

Monkey 可檢測 ANR 等;

TraceView 可跟蹤代碼的執行時間;


traceview 參考:

http://blog.csdn.net/androiddevelop/article/details/8223805

一、TraceView工具如何使用

TraceView有兩種啓動/關閉分析方式:

(1) 第一種使用方法演示

1、 選擇跟蹤範圍

在想要根據的代碼片段之間使用以下兩句代碼

  1. Debug.startMethodTracing("love_world_");  
  2. Debug.stopMethodTracing();  

例如,onCreate與onStart方法之間方法跟蹤
  1. public class MainActivity extends Activity {  
  2.   
  3.     @Override  
  4.     protected void onCreate(Bundle savedInstanceState) {  
  5.         super.onCreate(savedInstanceState);  
  6.         setContentView(R.layout.activity_main);  
  7.           
  8.         Debug.startMethodTracing("Love_World_");  
  9.     }  
  10.   
  11.     @Override  
  12.     protected void onStart() {  
  13.         super.onStart();  
  14.           
  15.         Debug.stopMethodTracing();  
  16.     }  
  17.       
  18. }  




2、添加SD卡訪問權限

  1. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>  
  2. <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>    


如果不添加,執行項目會出現以下異常
  1. java.lang.RuntimeException:Unable to open trace file '/mnt/sdcard/Love_World_.trace': Permission denied  

如果手機沒有SD卡也會出現同樣的問題

3、 導出traceview文件

1  首先執行項目,查看trace文件是否生成
進入shell模式

  1. adb shell  

查看是否已經生成這個文件
  1. ls sdcard/Love_World_.trace  

Ctrl + C 退出adb shell模式

2 導出trace文件
  1. adb pull sdcard/Love_World_.trace  


4、 打開trace文件


打開trace文件需要Android提供的traceview.bat工具,工具所在目錄:sdk\tools\traceview.bat, 有兩種方式執行:
1) 在命令行中切換到此目錄
2) 將此目錄添加到系統環境變量中

  1. //  cmd在calc.trace所在目錄執行  
  2. traceview C:\Users\YourName\Desktop\Love_World_.trace  

其中“C:\Users\YourName\Desktop\” 表示trace所在你係統中的目錄,此工具需要輸入trace文件的絕對路徑纔行


在新版本的SDK 會有以下提示:

  1. The standalone version of traceview is deprecated.  
  2. Please use Android Device Monitor (tools/monitor) instead.  

所以建議使用tools/monitor 啓動後跟Eclipse DDMS界面差不多,然後File -> Open File -> 選擇trace文件

5、異常處理

1 異常處理
  1. 'C:\Windows\system32\java.exe' 不是內部或外部命令,也不是可運行的程序  
  2. 或批處理文件。  
  3. SWT folder '' does not exist.  
  4. Please set ANDROID_SWT to point to the folder containing swt.jar for your platfo  
  5. rm.  

配置Java環境變量,把java bin 添加到系統環境變量PATH中



2 異常信息
  1. The standalone version of traceview is deprecated.  
  2. Please use Android Device Monitor (tools/monitor) instead.  
  3. Failed to read the trace filejava.io.IOException: Key section does not have an *  
  4. end marker  
  5.         at com.android.traceview.DmTraceReader.parseKeys(DmTraceReader.java:420)  
  6.   
  7.   
  8.         at com.android.traceview.DmTraceReader.generateTrees(DmTraceReader.java:  
  9. 91)  
  10.         at com.android.traceview.DmTraceReader.<init>(DmTraceReader.java:87)  
  11.         at com.android.traceview.MainWindow.main(MainWindow.java:286)  

通常是trace文件有異常,再重新生成並導出試試

3. 沒有SD卡會出現異常

  1. Unable to open trace file '/sdcard/Love_World_.trace': Permission denied  
  2.  Caused by: java.lang.RuntimeException: Unable to open trace file '/sdcard/Love_World_.trace': Permission denied  

生成的trace系統自動放在SDCARD上,沒有sd卡所以會出現這種異常


(2)  第二種使用方法演示

Eclipse -> DDMS -> Start Method Profiling




以上二者的區別,第一種方式更精確到方法,不方便的地方是自己需要添加方法並且要導出文件,第二種方式的優缺點剛好相反。


<圖片><圖片>

二、 TraceView工具面板介紹

有兩方面用途: 

1  查看跟蹤代碼的執行時間,分析哪些是耗時操作  

2  可以用於跟蹤方法的調用,尤其是Android Framework層的方法調用關係


獲取方法的調用順序

1. 在traceview中搜索響應的方法名不能使用大寫字母

2. 搜索出的方法會自動展開,其中包含Parents 和 Children 兩組信息

3. 點擊Parents下的方法名,直接跳轉到調用當前的方法處。Children相反




Traceview 面板分上下兩部分
上面是時間軸面板 (Timeline Panel)
     左側顯示的是線程信息
     右側黑色部分是顯示執行時間段、白色是線程暫停時間段,
     右側鼠標放在上面會出現時間線縱軸,在頂部會顯示當前時間線所執行的具體函數信息
下面是分析面板(Profile Panel) -  每一列內容
Inclusive time  - 函數本身運行花費時間 + 函數調用其他函數時間

Exclusive time - 函數本身運行花費時間。

Calls + RecurCall/Total 調用 + 重複調用次數 / 函數總調用次數

Cpu Time/Call 總的Cpu時間與總的調用次數之比

1-1  Profile Panel各列作用說明

列名

描述

Name

該線程運行過程中所調用的函數名

Incl Cpu Time

某函數佔用的CPU時間,包含內部調用其它函數的CPU時間

Excl Cpu Time

某函數佔用的CPU時間,但不含內部調用其它函數所佔用的CPU時間

Incl Real Time

某函數運行的真實時間(以毫秒爲單位),內含調用其它函數所佔用的真實時間

Excl Real Time

某函數運行的真實時間(以毫秒爲單位),不含調用其它函數所佔用的真實時間

Call+Recur Calls/Total

某函數被調用次數以及遞歸調用佔總調用次數的百分比

Cpu Time/Call

某函數調用CPU時間與調用次數的比。相當於該函數平均執行時間

Real Time/Call

CPU Time/Call類似,只不過統計單位換成了真實時間




三、如何進行具體的分析

有兩個問題需要解決:


1. 如何定位到所關心的地方? 

上面只是介紹瞭如何使用TraceView且有兩種用法,但是有時使用第一種方式範圍又不太精確,使用第二種添加代碼的方式,可能有些地方又監聽不到。這種情況可以嘗試把開始或者結束放到延遲線程中,延遲一段時間在執行開始或者結束。


2. 如何查找出哪些地方比較耗時?

TraceView羅列出了是所有監聽到的方法,當然也包括Android系統很多方法的耗時,如何在這麼多方法裏面查找到自己關心的? 可以通過TraceView 底部的find 來查找,通常Android app都是有包名的,可以先針對某些關心的列排序後,在通過包名進行一個個查找,這些就省去自己篩選出自己app 方法耗時排行的時間。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章