本文未使用Android Studio内置Profile分析工具,其一是因为使用时AS明显卡顿一不小心就会无响应,其二部分应用无法连接AS 抓取日志,因此采取最原始但是最万能的方式 adb 抓取 + MAT分析
文章目录
- 1 查看内存情况 adb shell dumpsys meminfo com.gerry.lifecycle
- 2 dump hprof 并转成 mat格式
- 3 分析 hprof
1 查看内存情况 adb shell dumpsys meminfo com.gerry.lifecycle
TOTAL PSS: App进程总内存,313146 KB = 305M
Java Heap: Java堆内存,hprof文件中的内存主要是来自这里, 250476KB = 244M
2 dump hprof 并转成 mat格式
adb shell am dumpheap com.gerry.lifecycle /data/local/tmp/demo.hprofadb pull /data/local/tmp/demo.hprof /Users/liangchaojie/Desktop/mem/demo.hprofhprof-conv /Users/liangchaojie/Desktop/mem/demo.hprof /Users/liangchaojie/Desktop/mem/demo_mat.hprof
3 分析 hprof
使用之前提到的 MAT 工具打开 demo_mat.hprof MAT安装教程在这里在这里!
整个hprof文件221.9M,MainActivity这个对象所引用的对象内存总共205.4M,占比 92.56%,我们点击进入Dominator Tree来分析最大对象是什么
我们发现MainActivity及其引用的对象内存是215389872 byte = 205.4 MB,占比确实是 92.5%,重点看这个对象引用了哪些对象
右键点击
MainActivity 类内部有一个 list 集合,放了这10000000个对象,检查代码如下
至此问题就定位到了,原来是创建了很多 Person对象导致的,每个对象多大内存呢?大概16byte