当前位置: 首页 > news >正文

移动端性能专项测试之内存 - 进阶篇

在 Android 系统中内存作为重要的资源,一直是开发及测试关注的重点,内存不足或者内存资源滥用都会导致严重的问题。本篇文章将会从底层出发给大家介绍 OOM(Out Of Memory)和 LMK(Low Memory Killer)等内存相关的知识。

在 Android 系统架构中,进程可以大体分成两类,一类是 Native 进程,另外一类就是 Java 进程

Native进程

采用 C/C++ 实现,本质上是 Linux 进程,在/system/bin/目录下面的程序文件运行后都是以 native 进程形式存在的。

Java进程

Android 虚拟机(Dalvik 或者 ART)实例的 Linux 进程,进程的入口 main 函数为 Java 函数。Android 虚拟机实例的宿主进程是 fork()系统调用创建的 Linux 进程,所以每一个 Android 上的 Java 进程实际上就是一个 Linux 进程,只是进程中多了一个 Android 虚拟机实例。因此,Java 进程的内存分配比 native 进程复杂,Android 系统中的应用程序基本都是 Java 进程,如桌面、电话、联系人、状态栏等等。

01Android 内存限制

Android 系统为每一个 App 设置了可使用的 Heap(堆内存)大小限制,可以进入到 shell 环境中,找到 build.prop 文件

cat /system/build.prop

  1. dalvik.vm.heapstartsize=8m

  2. app启动后, 系统分配给它的Heap初始大小. 随着App使用可增加

  3. dalvik.vm.heapgrowthlimit=192m

  4. 默认情况下, App可使用的Heap的最大值, 超过这个值就会产生OOM

  5. dalvik.vm.heapsize=512m

  6. 如果App的manifest文件中配置了largeHeap属性, 如下.则App可使用的Heap的最大值为此项设定值

  7. dalvik.vm.heaptargetutilization=0.75

  8. 当前理想的堆内存利用率. GC后, Dalvik的Heap内存会进行相应的调整, 调整到当前存活的对象的大小和 / Heap大小 接近这个选项的值, 即这里的0.75. 注意, 这只是一个参考值.

  9. dalvik.vm.heapminfree=2m

  10. 单次Heap内存调整的最小值

  11. dalvik.vm.heapmaxfree=8m

  12. 单次Heap内存调整的最大值

02LMK(Low Memory Killer)

在用户空间中指定了一组内存临界值,当其中的某个值与进程描述中的 oom_adj 值在同一范围时,该进程将被 Kill 掉。如果你的 APP 某个进程需要一直保存存活,你需要保持你的进程优先级足够高,并且占用比较小,因为 Low Memory Killer 在工作时,同一优先级的进程会先 kill 那个占用最大的。性能测试时主要关注待机时的内存是不是够小。

Low Memory Killer 的工作可能致系统变卡。为什么呢?因为它 kill 了一些进程,然而现在市面的很多 APP 为了保活都会自启,刚刚被 kill,立刻又起来。启动占用大量内存(还有 CPU),又触发 Low Memory Killer。频繁的被 kill 和启动形成了恶性循环,so…系统变的很卡。

03OOM 与 LMK 关系

Google 为什么设定当 Java 进程申请的 Java 空间超过阈值时,就抛出 OOM 异常?

  • 为了让 Android 系统能同时让比较多的进程常驻内存,这样程序启动时就不用每次都重新加载到内存,能够给用户更快的响应。

  • 程序发生 OOM 并不表示 RAM 不足,而是因为程序申请的 Java heap 对象超过了虚拟机配置的 heapgrowthlimit。也就是说,在 RAM 充足的情况下,也可能发生 OOM。

如果 RAM 真的不足,会发生什么呢?

  • 这时 Android 的 memory killer(LMK)会起作用,当 RAM 所剩不多时,memory killer 会杀死一些优先级比较低的进程来释放物理内存,让高优先级程序得到更多的内存。

ps:可以通过 adb shell cat /proc/meminfo 查看 RAM 的使用情况。

04绕过 dalvikvm heapsize 的限制

对于一些大型的应用程序(比如游戏),内存使用会比较多,很容易超出虚拟机 heapsize 的限制,这时怎么保证程序不会因为 OOM 而崩溃呢?

  • 创建子进程
    创建一个新的进程,那么我们就可以把一些对象分配到新进程的 heap 上了,从而达到一个应用程序使用更多的内存的目的,当然,创建子进程会增加系统开销,而且并不是所有应用程序都适合这样做,视需求而定。

  • 使用 jni 在 native heap 上申请空间

    native heap 的增长并不受 dalvik vm heapsize 的限制,只要 RAM 有剩余空间,程序员可以一直在 native heap 上申请空间,当然如果 RAM 快耗尽,LMK 会杀进程释放 RAM。大家使用一些软件时,有时候会闪退,就可能是软件在 native 层申请了比较多的内存导致的。

感谢每一个认真阅读我文章的人,礼尚往来总是要有的,虽然不是什么很值钱的东西,如果你用得到的话可以直接拿走:

这些资料,对于【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴上万个测试工程师们走过最艰难的路程,希望也能帮助到你!有需要的小伙伴可以点击下方小卡片领取

http://www.jsqmd.com/news/193429/

相关文章:

  • GLM-TTS与Zookeeper协同:分布式锁与配置管理
  • GLM-TTS在极地科考站的低温环境运行稳定性测试
  • 3dgs——MILO中的compute_depth_order_loss
  • 【PHP服务监控告警全攻略】:5种高实效告警方式揭秘,提升系统稳定性
  • 导师推荐9个AI论文网站,继续教育学生轻松搞定毕业论文!
  • PHP分库分表最佳实践(千万级数据处理秘籍)
  • Pytest测试用例中的mark用法(包含代码示例与使用场景详解)
  • 2025年珠宝柜台制作厂家权威推荐榜单:箱包展柜制作/专业制作展柜/烤漆柜台制作/珠宝品牌展柜/柜台制作源头厂家精选 - 品牌推荐官
  • 2026年重庆优质教育咨询机构最新推荐:海瑟教育,助力升学备考新征程 - 海棠依旧大
  • GLM-TTS与大数据平台对接:处理海量文本转语音需求
  • 2025年当地正规的上门家教老师联系方式,师范家教/数学家教/上门家教/初中家教/英语家教,上门家教老师口碑推荐 - 品牌推荐师
  • GLM-TTS与MathType结合设想:公式朗读辅助学习工具
  • 如何贡献代码?参与GLM-TTS开源社区建设路径
  • 2026年上半年成都食品添加剂/香精香料/调味料行业竞争分析报告 - 2025年品牌推荐榜
  • 语音合成灰度总结报告:全面评估试点成果
  • 模块化编程入门:JavaScript开发者如何告别代码混乱(附实战技巧)
  • 纯干货!3分钟教你免费克隆任何声音!
  • 移动端适配挑战:将GLM-TTS集成至Android/iOS应用
  • 2026初级药师复习资料怎么选?上岸前辈实战清单 - 医考机构品牌测评专家
  • 8款AI辅助论文查重工具推荐,提升学术写作效率,确保内容原创无忧
  • 语音合成自动化测试框架设计:保障功能稳定性
  • 2026餐饮连锁、便利店、高奢酒店、咖啡馆全场景商用智能咖啡机推荐 - 品牌2026
  • rust开源库test_case参数化测试
  • Flutter `audio_service` 在鸿蒙端的后台音频服务适配实践
  • GLM-TTS与JavaScript前端交互:动态加载生成音频
  • GLM-TTS在气象预警信息发布中的时效性保障措施
  • 用AI分析测试失败日志:自动归因的开源工具全景指南
  • FIFO学习记录
  • AI技术加持,8款高效查重工具推荐,让学术写作过程更加顺畅无忧
  • ‌互动学习游戏稳定性测试:幼儿教育场景的专业实践指南