[Android]生成heap dump文件(.hprof)
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
本文属sodino原创,发表于博客:http://blog.csdn.net/sodino,转载请注明出处。
相关代码可以从QQ群Code2Share(363267446)中的群文件中下载。
Android代码生成dump文件如下:
public static boolean 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" />
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。