我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Android adb shell 查看App内存(java堆内存/vss虚拟内存/详细的内存状况/内存快照hprof)和系统可用内存

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Android adb shell 查看App内存(java堆内存/vss虚拟内存/详细的内存状况/内存快照hprof)和系统可用内存

1.adb shell 获取app 进程的pid

adb shell "ps|grep com.xxx包名"

根据某个渠道包,去查询对应的pid,如下所示:
在这里插入图片描述

2.通过adb shell 查看设备的java dalvik 堆内存的最大值

执行命令行:

adb shell  getprop dalvik.vm.heapgrowthlimit

在这里插入图片描述
若是app进程中java heap(dalvik heap size) 堆内存超过384m 就会抛出oom.

若是app mainfest.xml 中设置了largeHeap=“true”,则app 进程dalvik heap limit 对应512m 限制。

在这里插入图片描述

3.查看app进程的物理rss、虚拟内存vss情况

adb shell procrank(需要手机 root 权限),可忽略该命令。

考虑使用Top 命令行格式:

adb shell top -n 1 |findstr "packageInfo"

以4399渠道包为案例,执行的adb shell top -n 1 |findstr "\ \"
在这里插入图片描述
或者通过adb shel 查询进程status 方式:

执行命令格式:

adb shell  cat /proc/app的pid/status

在这里插入图片描述
注意点:在32位(非arm64位)下,app进程中虚拟内存的峰值时3G 多,比较容易触发oom 情况。

4.通过adb shell 命令行查看app进程中内存状况:

格式:

adb shell dumpsys meminfo [pkg/pid]

可以用来查看指定进程包名的内存使用情况
执行adb shell dumpsys meminfo com.minitech.xxxx.m4399, 可以清楚知道java heap 、native heap、数据库、asset 等 ,内存数值是以KB为单位。

C:\Users\hexingen>adb shell dumpsys meminfo com.minitech.xxx.m4399Applications Memory Usage (in Kilobytes):Uptime: 4282829 Realtime: 4282829** MEMINFO in pid 14622 [com.minitech.miniworld.m4399] **                   Pss  Private  Private  SwapPss     Heap     Heap     Heap                 Total    Dirty    Clean    Dirty     Size    Alloc     Free                ------   ------   ------   ------   ------   ------   ------  Native Heap   455496   455468        8        0   596992   484213   112777  Dalvik Heap    26347    26328        0        0    45768    29384    16384 Dalvik Other     6178     6176        0        0        Stack     3844     3844        0        0       Ashmem     5561     5092        0        0    Other dev       28        0       28        0     .so mmap    62819     5104    55760       36    .jar mmap        4        0        4        0    .apk mmap    49281     9980    38240        0    .ttf mmap     1031        0      768        0    .dex mmap    24272       16    24228        0    .oat mmap     8604        0     3968        0    .art mmap     3794     2224      588        2   Other mmap     6361       20     6076        0    GL mtrack   152964   152964        0        0      Unknown    79528    79528        0        1        TOTAL   886151   746744   129668       39   642760   513597   129161 App Summary                       Pss(KB)                        ------           Java Heap:    29140 //java 堆所占用的物理内存         Native Heap:   455468 //native 堆所占用的物理内存                Code:   138068               Stack:     3844            Graphics:   152964       Private Other:    96928              System:     9739               //app进程中占有物理内存(等于uss+按比列的共享库物理内存)               TOTAL:   886151       TOTAL SWAP PSS:       39 Objects // 进程中关键对象情况 ,activity \binder 个数,可看内存泄漏               Views:      166         ViewRootImpl:        2         AppContexts:        5           Activities:        4              Assets:        7        AssetManagers:        4       Local Binders:       71        Proxy Binders:       40       Parcel memory:       40         Parcel count:      155    Death Recipients:        2      OpenSSL Sockets:        8 SQL         MEMORY_USED:     1092  PAGECACHE_OVERFLOW:      342          MALLOC_SIZE:       79 DATABASES //进程中数据库db 打开情况      pgsz     dbsz   Lookaside(b)          cache  Dbname         4       40            480      222/96/23  /data/user/0/com.minitech.miniworld.m4399/databases/pangle_com.byted.pangle_bd_embed_tea_agent.db         4       24             31         2/20/3  /data/user/0/com.minitech.miniworld.m4399/databases/tracker.db         4       52             91       21/29/12  /data/user/0/com.minitech.miniworld.m4399/databases/bugly_db_         4       92            200     478/108/25  /data/user/0/com.minitech.miniworld.m4399/databases/pangle_com.byted.pangle_ttopensdk.db         4       24             98         1/37/4  /data/user/0/com.minitech.miniworld.m4399/databases/pangle_com.byted.pangle_downloader.db         4       20             17         0/30/3  /data/user/0/com.minitech.miniworld.m4399/databases/pangle_com.byted.pangle_npth_log.db         4       16             41        13/21/6  /data/user/0/com.minitech.miniworld.m4399/files/MobSDK/comm/dbs/.dh Asset Allocations  //进程中asset 打开情况    : 1K    zip:/data/user/0/com.minitech.miniworld.m4399/files/pangle_p/com.byted.pangle/version-4908/apk/base-1.apk:/resources.arsc: 98K

一般情况下,仅需关注 Pss Total 和 Private Dirty 列。 在某些情况下,Private Clean 和 Heap Alloc 列提供的数据也值得关注。

接下来,详细分析下以上的数据:

查看java 堆内存使用
在这里插入图片描述
若是dalvik heap size 超过jvm 阀值(通常384M 或者512M)时,就会触发java heap 导致oom。

查看进程中pss 物理内存使用情况

  • Pss total : 占用的物理内存
  • Private Dirty: app进程死亡结束后,系统可回收的arm 物理内存
  • Private clean: 当前app进程中已被系统回收的arm 物理内存
    在这里插入图片描述
    若app 进程中pss 物理内存越来越大,系统中arm处理器的可用物理内存越来越少,直到可用物理内存不够分配时,就会触发oom。

查看内存泄漏

AppContexts 和 Activities和ViewRootImpl 表示当前 进程中context 个数和activity个数,根view视图(即phonewindow) 个数据,结合业务查看是否超过当前存在的个数,若是超过,则发生内存泄漏,被静态或者单例类所间接持有。
在java se 中被强引用的对象,是无法被回收的

更多adb shell dumpsys meminfo 详解:https://blog.51cto.com/u_4387387/6077172。

另外:/proc/pid/maps 和/proc/pid/smaps 通过adb shell 执行需要权限,暂时无法使用。
在这里插入图片描述

5.查看当前的手机系统内存情况:

执行adb shell cat /proc/meminfo ,可查看手机处理器内存 ,当前可用的内存
在这里插入图片描述
当MemAvailable 可用内存大小越来越少,直到耗尽就触发oom。

6.adb shell 获取内存快照hrop:

执行命令行:

adb shell am dumpheap package包名 /data/local/tmp/xxx.hprof

在这里插入图片描述
执行命令行,等待执行完。通过文件 浏览器或者studio的文件管理,找到该文件,双击打开,就可以查看到详细的内存快照。
在这里插入图片描述

来源地址:https://blog.csdn.net/hexingen/article/details/131934734

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Android adb shell 查看App内存(java堆内存/vss虚拟内存/详细的内存状况/内存快照hprof)和系统可用内存

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录