Android打印各进程的内存

一、背景       

       对于物联网设备,因为成本原因,分配到的内存是很有限,导致业务拓展上经常出现内存溢出,内存不够用的情况,导致业务停滞不前。在这样的背景下,进程化架构应运而生,将各个业务块做成一个个进程,这样在同样的业务需求,可分配到内存达到最大化,方便后续业务拓展。

       本篇文章并不是介绍进程化架构,而是在进程化架构环境下,如果在主进程打印各个子进程的内存使用及分配的总内存。

二、代码

private void memoryInfo() {
    long availeMemory = MemoryUtil.getAvailMemory(LzApplication.getApplication());
    long allMemory = MemoryUtil.getTotalMemory(LzApplication.getApplication());
    boolean isRunLowMemory = MemoryUtil.isRunLowMemory(LzApplication.getApplication());
    Map<String,String> mainMemory = MemoryUtil.getAppMemoryUsage(LzApplication.getApplication(),"com.machine.xxx");
    Map<String,String> faceMemory = MemoryUtil.getAppMemoryUsage(LzApplication.getApplication(),"com.machine.xxx:face");
    Map<String,String> taskMemory = MemoryUtil.getAppMemoryUsage(LzApplication.getApplication(),"com.machine.xxx:task");

    LogUtil.i(TAG, "memoryInfo>> 所有进程内存使用" + ",系统的总内存:" + allMemory +
            "M,系统可用内存有:" + availeMemory +
            "M,系统是否处于低内存:" + isRunLowMemory +
            ",主进程分配内存:" + mainMemory.get("usage") +
            "M,主进程使用内存:" + mainMemory.get("used") +
            "M,人脸子进程分配内存:" + faceMemory.get("usage") +
            "M,人脸子进程使用内存:" + faceMemory.get("used") +
            "M,任务子进程分配内存:" + taskMemory.get("usage") +
            "M,任务子进程使用内存:" + taskMemory.get("used"));
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

互联网求职宝典

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值