Android生成heap dump檔案轉
阿新 • • 發佈:2019-02-07
Android生成heap dump檔案(.hprof)
一個heap dump就是一個程式heap的快照,可以獲知程式的哪些部分正在使用大部分的記憶體。
它儲存為一種叫做HPROF的二進位制格式。對於Android執行android.os.Debug.dumpHprofData(hprofPath)方法後所生成的檔案,需要把.hprof檔案從Dalvik格式轉換成J2SE HPROF格式。使用AndroidSDK提供的hprof-conv工具可執行該轉換操作。
- hprof-conv dump.hprof converted-dump.hprof
相關程式碼可以從QQ群Code2Share(363267446)中的群檔案中下載。
Android程式碼生成dump檔案如下:
- publicstaticboolean createDumpFile(Contextcontext) {
- StringLOG_PATH = "/dump.gc/";
- boolean bool = false;
- SimpleDateFormatsdf = new SimpleDateFormat("yyyy-MM-dd_HH.mm.ssss");
- StringcreateTime = sdf.format(new Date(System.currentTimeMillis()));
-
Stringstate = android.os.Environment.getExternalStorageState();
- // 判斷SdCard是否存在並且是可用的
- if(android.os.Environment.MEDIA_MOUNTED.equals(state)){
- Filefile = new File(Environment.getExternalStorageDirectory().getPath() +LOG_PATH);
- if(!file.exists()) {
- file.mkdirs();
- }
-
StringhprofPath = file.getAbsolutePath();
- if(!hprofPath.endsWith("/")) {
- hprofPath+= "/";
- }
- hprofPath+= createTime + ".hprof";
- try {
- android.os.Debug.dumpHprofData(hprofPath);
- bool= true;
- Log.d("ANDROID_LAB", "create dumpfile done!");
- }catch (IOException e) {
- e.printStackTrace();
- }
- } else {
- bool= false;
- Log.d("ANDROID_LAB", "nosdcard!");
- }
- return bool;
- }
不要忘記了在AndroidManifest.xml中宣告SDCard寫許可權:
- <uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE" />