[轉]Android TraceView工具使用

1、 選擇跟蹤範圍html

在想要根據的代碼片斷之間使用如下兩句代碼java

[java]  view plain copy print ?
  1. Debug.startMethodTracing("love_world_");  
  2. Debug.stopMethodTracing();  


例如,onCreate與onStart方法之間方法跟蹤android

[java]  view plain copy print ?
  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卡訪問權限sql

[html]  view plain copy print ?
  1. <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>  
  2. <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>    

 

 

若是不添加,執行項目會出現如下異常shell

[java]  view plain copy print ?
  1. java.lang.RuntimeException:Unable to open trace file '/mnt/sdcard/Love_World_.trace': Permission denied  




三 、 導出traceview文件app

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

  1. adb shell  


查看是否已經生成這個文件工具

[plain]  view plain copy print ?
  1. ls sdcard/Love_World_.trace  


Ctrl + C 退出adb shell模式

2 導出trace文件oop

[plain]  view plain copy print ?
  1. adb pull sdcard/Love_World_.trace  



4、 打開trace文件

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

spa

[plain]  view plain copy print ?
  1. //  cmd在calc.trace所在目錄執行  
  2. traceview C:\Users\YourName\Desktop\Love_World_.trace  


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


5、 TraceView工具用途

 

有兩方面用途: 

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

2  能夠用於跟蹤方法的調用,尤爲是Android Framework層的方法調用關係

 

獲取方法的調用順序

 

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

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

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






6、異常處理
1 異常處理

[plain]  view plain copy print ?
  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 異常信息

[plain]  view plain copy print ?
  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文件有異常,再從新生成並導出試試

 

7、 相關資料:

念茜 : Android代碼調試工具 traceview 和 dmtracedump的波折演繹 

 

 

原文地址: http://blog.csdn.net/love_world_/article/details/8223805

相關文章
相關標籤/搜索