天天看點

[Android]Android TraceView工具使用

一、 選擇跟蹤範圍

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

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_");

    }

    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檔案有異常,再重新生成并導出試試

七、 相關資料: