记一次 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

相关推荐
2501_944424122 小时前
Flutter for OpenHarmony游戏集合App实战之贪吃蛇食物生成
android·开发语言·flutter·游戏·harmonyos
卓码软件测评3 小时前
第三方软件测试测评机构【使用web_reg_save_param_ex函数:掌握LoadRunner关联的黄金法则 】
测试工具·ci/cd·性能优化·单元测试·测试用例
2501_937145415 小时前
神马影视8.8版2026最新版:核心技术升级与多场景适配解析
android·源码·电视盒子·源代码管理
2501_944424126 小时前
Flutter for OpenHarmony游戏集合App实战之俄罗斯方块七种形状
android·开发语言·flutter·游戏·harmonyos
不会Android的潘潘8 小时前
受限系统环境下的 WebView 能力演进:车载平台 Web 渲染异常的根因分析与优化实践
android·java·前端·aosp
建军啊8 小时前
java web常见lou洞
android·java·前端
豆奶dudu8 小时前
安卓应用签名生成+微信开放平台安卓应用签名
android·微信开放平台
AC赳赳老秦9 小时前
Dify工作流+DeepSeek:运维自动化闭环(数据采集→报告生成)
android·大数据·运维·数据库·人工智能·golang·deepseek
2501_9444241210 小时前
Flutter for OpenHarmony游戏集合App实战之记忆翻牌配对消除
android·java·开发语言·javascript·windows·flutter·游戏
2501_9445264210 小时前
Flutter for OpenHarmony 万能游戏库App实战 - 设置功能实现
android·javascript·flutter·游戏·harmonyos