Android抓取各種log的方法
中相關變數情況等。
在android 中抓取app 的hprof 操作方式有下面幾種:
第一種方式: 使用am 命令
adb shell am dumpheap {Process} file
如 adb shell am dumpheap com.android.phone /data/anr/phone.hprof
adb pull /data/anr/phone.hprof
第二種方式: 使用DDMS 命令
在DDMS 中選擇對應的process, 然後在Devices 按鈕欄中選擇Dump Hprof file, 儲存即可
第三種方式: 通過程式碼的方式
在android.os.Debug 這個class 中有定義相關的抓取hprof 的method.
如: public static void dumpHprofData(String fileName) throws IOException;
這樣即可在程式碼中直接將這個process 的hprof 儲存到相對應的檔案中,注意這個只能抓取當時的
process.
如果想抓其他的process 的hprof, 那麼就必須通過AMS 幫忙了。
可以先獲取IActivityManager 介面,然後呼叫它的dumpheap 方法。具體的程式碼,大家可以參考
frameworks/base/cmds/am/src/com/android/commands/am/am.java 中的呼叫程式碼
抓取回hprof 後,就可以用hprof-conv 命令將DVM 格式的hprof 轉換成標準的java 命令的hprof
hprof-conv in.hprof out.hprof
然後使用如MAT 之類的工具進行具體的分析