本文为
Android 电量管理
系列连载的第四篇,希望可以为各位开发者提供设备续航方面的战略洞见和实践指南。
Android 进程管理机制
作为一款移动端操作系统,Android 在设计之初就考虑到了诸如内存和电量一类的资源限制问题。因此,系统在内存吃紧的情况下会关闭部分进程,以此来为优先级更高的任务腾出运行空间。那么系统是如何评判优先级高低的呢?判断标准其实很简单,关键就在于应用进程对用户有多重要。Android 将进程分为以下几类,按重要性的高低做降序排列,进程排名越靠前,被回收的几率就越低。
前台服务
应用产生缓存很正常: 每个开发者应该认识到,共享设备资源是生命周期管理的一部分,这样才有助于营造健康的 Android 生态环境。当电池电量耗尽时,所有应用都无法继续使用,而导致耗电异常的应用则会面临卸载风险。
不过在特定情况下,开发者的确需要把应用从后台转到前台运行。当应用所执行的任务同时满足以下条件时,您可以为其创建前台服务,直至任务运行结束: (1) 需要立即执行; (2) 重要 (必须完成); (3) 用户可感知 (大部分情况下由用户主动发起); (4) 有明确的起始时间和结束时间。
为了帮助您更好地创建和管理前台服务,我们特别为总结了以下 3 个操作要点:
-
适用于所有 API 等级: 应用创建服务时,必须显示级别至少为 PRIORITY_LOW 的 常驻通知 (persistent notification)。
-
若应用的目标 API 等级高于 26,您还需要将通知渠道的级别至少设定为 IMPORTANCE_LOW 。用户可以点击通知来取消任务,且取消操作可与 action 绑定,例如,当用户停止播放曲目后,回放服务也会一同停止。
-
通知标题和描述必须准确体现前台服务正在执行的操作。
如果您想了解有关前台服务的更多信息,包括最近几个版本 Android 平台内的相关重要更新,请参阅《 在前台运行服务 》。
前台服务典型用例
前台服务的典型用例包括播放音乐、完成购买交易、高精度地理位置追踪 (健身应用) 以及感应器数据录入 (监测用户的睡眠状态)。这些工作均由用户主动发起,需要立刻执行,并且具备明确的起始时间和结束时间,而且允许用户随时取消操作。