標籤:des android c class java a
一、 選擇跟蹤範圍
在想要根據的程式碼片段之間使用以下兩句代碼
- Debug.startMethodTracing("love_world_");
- Debug.stopMethodTracing();
例如,onCreate與onStart方法之間方法跟蹤
- public class MainActivity extends Activity {
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setContentView(R.layout.activity_main);
- Debug.startMethodTracing("Love_World_");
- }
- @Override
- protected void onStart() {
- super.onStart();
- Debug.stopMethodTracing();
- }
- }
二、添加SD卡存取權限
- <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
- <uses-permission android:name="android.permission.MOUNT_UNMOUNT_FILESYSTEMS"/>
如果不添加,執行項目會出現以下異常
- java.lang.RuntimeException:Unable to open trace file ‘/mnt/sdcard/Love_World_.trace‘: Permission denied
三 、 匯出traceview檔案
1 首先執行項目,查看trace檔案是否產生
進入shell模式
- adb shell
查看是否已經產生這個檔案
- ls sdcard/Love_World_.trace
Ctrl + C 退出adb shell模式
2 匯出trace檔案
- adb pull sdcard/Love_World_.trace
四、 開啟trace檔案
開啟trace檔案需要Android提供的traceview.bat工具,工具所在目錄:sdk\tools\traceview.bat, 有兩種方式執行:
1) 在命令列中切換到此目錄
2) 將此目錄添加到系統內容變數中
- // cmd在calc.trace所在目錄執行
- 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 異常處理
- ‘C:\Windows\system32\java.exe‘ 不是內部或外部命令,也不是可啟動並執行程式
- 或批次檔。
- SWT folder ‘‘ does not exist.
- Please set ANDROID_SWT to point to the folder containing swt.jar for your platfo
- rm.
配置Java環境變數,把java bin 添加到系統內容變數PATH中
2 異常資訊
- The standalone version of traceview is deprecated.
- Please use Android Device Monitor (tools/monitor) instead.
- Failed to read the trace filejava.io.IOException: Key section does not have an *
- end marker
- at com.android.traceview.DmTraceReader.parseKeys(DmTraceReader.java:420)
- at com.android.traceview.DmTraceReader.generateTrees(DmTraceReader.java:
- 91)
- at com.android.traceview.DmTraceReader.<init>(DmTraceReader.java:87)
- at com.android.traceview.MainWindow.main(MainWindow.java:286)
通常是trace檔案有異常,再重建並匯出試試
七、 相關資料:
Android代碼調試工具 traceview 和 dmtracedump的波折演繹