记一次 Android 高内存排查

本文未使用Android Studio内置Profile分析工具,其一是因为使用时AS明显卡顿一不小心就会无响应,其二部分应用无法连接AS 抓取日志,因此采取最原始但是最万能的方式 adb 抓取 + MAT分析

文章目录

  • [1 查看内存情况 adb shell dumpsys meminfo com.gerry.lifecycle](#1 查看内存情况 adb shell dumpsys meminfo com.gerry.lifecycle)
  • [2 dump hprof 并转成 mat格式](#2 dump hprof 并转成 mat格式)
  • [3 分析 hprof](#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格式

bash 复制代码
adb shell am dumpheap com.gerry.lifecycle   /data/local/tmp/demo.hprof

adb pull /data/local/tmp/demo.hprof /Users/liangchaojie/Desktop/mem/demo.hprof

hprof-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

相关推荐
不爱说话郭德纲8 小时前
告别漫长的HbuilderX云打包排队!uni-app x 安卓本地打包保姆级教程(附白屏、包体积过大排坑指南)
android·前端·uni-app
BigByte12 小时前
我用 6 个 WASM 编码器干掉了 Canvas.toBlob(),图片压缩率直接提升 15%
性能优化·webassembly·图片资源
Sinclair13 小时前
简单几步,安卓手机秒变服务器,安装 CMS 程序
android·服务器
雮尘16 小时前
手把手带你玩转Android gRPC:一篇搞定原理、配置与客户端开发
android·前端·grpc
ktl17 小时前
Android 编译加速/优化 80%:一个文件搞定,零侵入零配置
android
alexhilton1 天前
使用FunctionGemma进行设备端函数调用
android·kotlin·android jetpack
冬奇Lab1 天前
InputManagerService:输入事件分发与ANR机制
android·源码阅读
DemonAvenger1 天前
Kafka性能调优:从参数配置到硬件选择的全方位指南
性能优化·kafka·消息队列
张小潇1 天前
AOSP15 Input专题InputManager源码分析
android·操作系统
桦说编程2 天前
实战分析 ConcurrentHashMap.computeIfAbsent 的锁冲突问题
java·后端·性能优化