android traceview工具,[Android]Android TraceView工具使用
一、 選擇跟蹤范圍
在想要根據(jù)的代碼片段之間使用以下兩句代碼
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卡訪問權限
如果不添加,執(zhí)行項目會出現(xiàn)以下異常
java.lang.RuntimeException:Unable?to?open?trace?file?‘/mnt/sdcard/Love_World_.trace‘:?Permission?denied
三 、 導出traceview文件
1 ?首先執(zhí)行項目,查看trace文件是否生成
進入shell模式
adb?shell
查看是否已經(jīng)生成這個文件
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,
有兩種方式執(zhí)行:
1) 在命令行中切換到此目錄
2) 將此目錄添加到系統(tǒng)環(huán)境變量中
//??cmd在calc.trace所在目錄執(zhí)行
traceview?C:\Users\YourName\Desktop\Love_World_.trace
其中“C:\Users\YourName\Desktop\” 表示trace所在你系統(tǒng)中的目錄,此工具需要輸入trace文件的絕對路徑才行
五、 TraceView工具用途
有兩方面用途:
1 ?查看跟蹤代碼的執(zhí)行時間,分析哪些是耗時操作
2 ?可以用于跟蹤方法的調(diào)用,尤其是Android Framework層的方法調(diào)用關系
獲取方法的調(diào)用順序
1. 在traceview中搜索響應的方法名不能使用大寫字母
2. 搜索出的方法會自動展開,其中包含Parents 和 Children 兩組信息
3. 點擊Parents下的方法名,直接跳轉(zhuǎn)到調(diào)用當前的方法處。Children相反
六、異常處理
1 異常處理
‘C:\Windows\system32\java.exe‘?不是內(nèi)部或外部命令,也不是可運行的程序
或批處理文件。
SWT?folder?‘‘?does?not?exist.
Please?set?ANDROID_SWT?to?point?to?the?folder?containing?swt.jar?for?your?platfo
rm.
配置Java環(huán)境變量,把java bin 添加到系統(tǒng)環(huán)境變量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.(DmTraceReader.java:87)
at?com.android.traceview.MainWindow.main(MainWindow.java:286)
通常是trace文件有異常,再重新生成并導出試試
七、 相關資料:
原文:http://www.cnblogs.com/webapplee/p/3774056.html
總結(jié)
以上是生活随笔為你收集整理的android traceview工具,[Android]Android TraceView工具使用的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Inter core i7处理器中(x8
- 下一篇: 什么是句柄什么是句柄对象