Android生成heap dump文件转

Android生成heap dump文件(.hprof)


一个heap dump就是一个程序heap的快照,可以获知程序的哪些部分正在使用大部分的内存。

它保存为一种叫做HPROF的二进制格式。对于Android执行android.os.Debug.dumpHprofData(hprofPath)方法后所生成的文件,需要把.hprof文件从Dalvik格式转换成J2SE HPROF格式。使用AndroidSDK提供的hprof-conv工具可执行该转换操作。

 

[java] view plaincopy在CODE上查看代码片派生到我的代码片
  1. hprof-conv dump.hprof converted-dump.hprof  

本文属sodino原创,发表于博客:http://blog.csdn.net/sodino,转载请注明出处。

相关代码可以从QQ群Code2Share(363267446)中的群文件中下载。

Android代码生成dump文件如下:

[java] view plaincopy在CODE上查看代码片派生到我的代码片
  1. public static boolean createDumpFile(Contextcontext) {  
  2.     StringLOG_PATH = "/dump.gc/";  
  3.     boolean bool = false;  
  4.     SimpleDateFormatsdf = new SimpleDateFormat("yyyy-MM-dd_HH.mm.ssss");  
  5.     StringcreateTime = sdf.format(new Date(System.currentTimeMillis()));  
  6.     Stringstate = android.os.Environment.getExternalStorageState();  
  7.     // 判断SdCard是否存在并且是可用的  
  8.     if(android.os.Environment.MEDIA_MOUNTED.equals(state)){  
  9.         Filefile = new File(Environment.getExternalStorageDirectory().getPath() +LOG_PATH);  
  10.         if(!file.exists()) {  
  11.             file.mkdirs();  
  12.         }  
  13.         StringhprofPath = file.getAbsolutePath();  
  14.         if(!hprofPath.endsWith("/")) {  
  15.             hprofPath+= "/";  
  16.         }                
  17.          
  18.         hprofPath+= createTime + ".hprof";  
  19.         try {  
  20.             android.os.Debug.dumpHprofData(hprofPath);  
  21.             bool= true;  
  22.             Log.d("ANDROID_LAB""create dumpfile done!");  
  23.         }catch (IOException e) {  
  24.             e.printStackTrace();  
  25.         }  
  26.     } else {  
  27.         bool= false;  
  28.         Log.d("ANDROID_LAB""nosdcard!");  
  29.     }  
  30.      
  31.     return bool;  
  32. }  

不要忘记了在AndroidManifest.xml中声明SDCard写权限:

[java] view plaincopy在CODE上查看代码片派生到我的代码片
  1. <uses-permissionandroid:name="android.permission.WRITE_EXTERNAL_STORAGE" />  


阅读更多
换一批

没有更多推荐了,返回首页