自助做网站,嘉兴做网站优化,安装wordpress数据库500,佛山营销型网站设计在 Android 系统中内存作为重要的资源#xff0c;一直是开发及测试关注的重点#xff0c;内存不足或者内存资源滥用都会导致严重的问题。本篇文章将会从底层出发给大家介绍 OOM#xff08;Out Of Memory#xff09;和 LMK#xff08;Low Memory Killer#xff09;等内存相…在 Android 系统中内存作为重要的资源一直是开发及测试关注的重点内存不足或者内存资源滥用都会导致严重的问题。本篇文章将会从底层出发给大家介绍 OOMOut Of Memory和 LMKLow 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 进程如桌面、电话、联系人、状态栏等等。
01、Android 内存限制
Android 系统为每一个 App 设置了可使用的 Heap(堆内存)大小限制可以进入到 shell 环境中找到 build.prop 文件
cat /system/build.prop
dalvik.vm.heapstartsize8m
app启动后, 系统分配给它的Heap初始大小. 随着App使用可增加
dalvik.vm.heapgrowthlimit192m
默认情况下, App可使用的Heap的最大值, 超过这个值就会产生OOM
dalvik.vm.heapsize512m
如果App的manifest文件中配置了largeHeap属性, 如下.则App可使用的Heap的最大值为此项设定值
dalvik.vm.heaptargetutilization0.75
当前理想的堆内存利用率. GC后, Dalvik的Heap内存会进行相应的调整, 调整到当前存活的对象的大小和 / Heap大小 接近这个选项的值, 即这里的0.75. 注意, 这只是一个参考值.
dalvik.vm.heapminfree2m
单次Heap内存调整的最小值
dalvik.vm.heapmaxfree8m
单次Heap内存调整的最大值
如果你想学习自动化测试我这边给你推荐一套视频这个视频可以说是B站播放全网第一的自动化测试教程同时在线人数到达1000人并且还有笔记可以领取及各路大神技术交流798478386
【已更新】B站讲的最详细的Python接口自动化测试实战教程全集实战最新版_哔哩哔哩_bilibili【已更新】B站讲的最详细的Python接口自动化测试实战教程全集实战最新版共计200条视频包括1、接口自动化之为什么要做接口自动化、2、接口自动化之request全局观、3、接口自动化之接口实战等UP主更多精彩视频请关注UP账号。https://www.bilibili.com/video/BV17p4y1B77x/?spm_id_from333.337vd_source488d25e59e6c5b111f7a1a1a16ecbe9a
02、LMK(Low Memory Killer)
在用户空间中指定了一组内存临界值当其中的某个值与进程描述中的 oom_adj 值在同一范围时该进程将被 Kill 掉。如果你的 APP 某个进程需要一直保存存活你需要保持你的进程优先级足够高并且占用比较小因为 Low Memory Killer 在工作时同一优先级的进程会先 kill 那个占用最大的。性能测试时主要关注待机时的内存是不是够小。
Low Memory Killer 的工作可能致系统变卡。为什么呢因为它 kill 了一些进程然而现在市面的很多 APP 为了保活都会自启刚刚被 kill立刻又起来。启动占用大量内存还有 CPU又触发 Low Memory Killer。频繁的被 kill 和启动形成了恶性循环so…系统变的很卡。
03、OOM 与 LMK 关系
Google 为什么设定当 Java 进程申请的 Java 空间超过阈值时就抛出 OOM 异常 为了让 Android 系统能同时让比较多的进程常驻内存这样程序启动时就不用每次都重新加载到内存能够给用户更快的响应。 程序发生 OOM 并不表示 RAM 不足而是因为程序申请的 Java heap 对象超过了虚拟机配置的 heapgrowthlimit。也就是说在 RAM 充足的情况下也可能发生 OOM。
如果 RAM 真的不足会发生什么呢 这时 Android 的 memory killerLMK会起作用当 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 层申请了比较多的内存导致的。