[Android]Android TraceView工具使用

來源:互聯網
上載者:User

標籤:des   android   c   class   java   a   

一、 選擇跟蹤範圍

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

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

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

  1. public class MainActivity extends Activity {
  2.     @Override
  3.     protected void onCreate(Bundle savedInstanceState) {
  4.         super.onCreate(savedInstanceState);
  5.         setContentView(R.layout.activity_main);
  6.         Debug.startMethodTracing("Love_World_");
  7.     }
  8.     @Override
  9.     protected void onStart() {
  10.         super.onStart();
  11.         Debug.stopMethodTracing();
  12.     }
  13. }

二、添加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

三 、 匯出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

四、 開啟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檔案的絕對路徑才行

五、 TraceView工具用途

 

有兩方面用途:

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

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

 

擷取方法的調用順序

 

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

2. 搜尋出的方法會自動延伸,其中包含Parents 和 Children 兩組資訊

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

六、異常處理
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.         at com.android.traceview.DmTraceReader.generateTrees(DmTraceReader.java:
  7. 91)
  8.         at com.android.traceview.DmTraceReader.<init>(DmTraceReader.java:87)
  9.         at com.android.traceview.MainWindow.main(MainWindow.java:286)

通常是trace檔案有異常,再重建並匯出試試

 

七、 相關資料:

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

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.