从 Android 6.0(API 级别 23)开始,Android 引入了两项省电功能,通过管理应用在设备未连接至电源时的行为方式,帮助用户延长电池寿命。当用户长时间未使用设备时,低电耗模式会延迟应用的后台 CPU 和网络活动,从而降低耗电量。应用待机模式会延迟用户近期未与之交互的应用的后台网络活动。
当设备处于低电耗模式时,应用对某些高耗电量资源的访问会延迟到维护期。电源管理限制中列出了具体的限制。
低电耗模式和应用待机模式管理在 Android 6.0 或更高版本上运行的所有应用的行为,无论它们是否专用于 API 级别 23。为确保用户获得最佳体验,请在低电耗模式和应用待机模式下测试您的应用,并对您的代码进行必要的调整。下面几部分提供了详细信息。
了解低电耗模式
如果用户未插接设备的电源,在屏幕关闭的情况下,让设备在一段时间内保持不活动状态,那么设备就会进入低电耗模式。在低电耗模式下,系统会尝试通过限制应用访问占用大量网络和 CPU 资源的服务来节省电量。它还会阻止应用访问网络,并延迟其作业、同步和标准闹钟。
系统会定期退出低电耗模式一小段时间,让应用完成其延迟的活动。在此维护期内,系统会运行所有待处理的同步、作业和闹钟,并允许应用访问网络。
在每个维护期结束时,系统会再次进入低电耗模式,暂停网络访问并推迟作业、同步和闹钟。随着时间的推移,系统安排维护期的次数越来越少,这有助于在设备未连接至充电器的情况下长期处于不活动状态时降低耗电量。
light idle:(第一级限制,图2中 第一个Doze阶段) 进入条件: 非充电状态且屏幕已关闭一定时间后 限制: 关闭应用网络访问、推迟作业和同步 deep idle:(第二级限制,图2中 第二个Doze阶段) 进入条件: 进入light idle模式后设备处于静止状态达到一定时间 限制: PowerManager.WakeLock、AlarmManager 闹铃、GPS 和 WLAN 扫描
低电耗模式限制(Doze mode)
在低电耗模式下,您的应用会受到以下限制:
暂停访问网络。
系统忽略唤醒锁定。
标准
AlarmManager
闹钟(包括setExact()
和setWindow()
)推迟到下一个维护期。如果您需要设置在设备处于低电耗模式时触发的闹钟,请使用
setAndAllowWhileIdle()
或setExactAndAllowWhileIdle()
。使用
setAlarmClock()
设置的闹钟将继续正常触发,系统会在这些闹钟触发之前不久退出低电耗模式。系统不执行 WLAN 扫描。
系统不允许运行同步适配器。
系统不允许运行
JobScheduler
。
低电耗模式核对清单
如果可能,请使用 FCM 进行下游消息传递。
如果您的用户必须立即看到通知,请务必使用 FCM 高优先级消息。
在初始消息负载中提供足够的信息,这样随后就无需访问网络。
使用
setAndAllowWhileIdle()
和setExactAndAllowWhileIdle()
设置重要闹钟。
使应用适应低电耗模式
低电耗模式可能会对应用产生不同的影响,具体取决于应用提供的功能和使用的服务。许多应用无需修改即可在低电耗模式周期内正常运行。在某些情况下,您必须优化应用管理网络、闹钟、作业和同步的方式。应用应该能够在每个维护期内高效地管理活动。
低电耗模式尤其可能会影响 AlarmManager
闹钟和定时器管理的活动,因为当系统处于低电耗模式时,不会触发 Android 5.1(API 级别 22)或更低版本中的闹钟。
为了帮助安排闹钟,Android 6.0(API 级别 23)引入了两种新的 AlarmManager
方法:setAndAllowWhileIdle()
和 setExactAndAllowWhileIdle()
。通过这些方法,您可以设置即使设备处于低电耗模式也会触发的闹钟。
注意:setAndAllowWhileIdle()
及 setExactAndAllowWhileIdle()
为每个应用触发闹钟的频率都不能超过每 9 分钟一次。
低电耗模式对网络访问的限制也有可能影响应用,特别是当应用依赖于操作消息或通知等实时消息时更是如此。如果应用需要与网络建立持久性连接来接收消息,您应尽可能使用 Firebase 云消息传递 (FCM)。
要确认应用在低电耗模式下的行为方式符合预期,您可以使用 adb 命令强制系统进入和退出低电耗模式并观察应用的行为。如需了解详情,请参阅在低电耗模式和应用待机模式下进行测试。
应用待机模式(APP Standby)
应用待机模式允许系统判定应用在用户未主动使用它时是否处于闲置状态。当用户有一段时间未触摸应用时,系统便会作出此判定,以下条件均不适用:
用户明确启动应用。
应用当前有一个进程在前台运行(作为活动或前台服务,或者正在由其他活动或前台服务使用)。
注意:您只能将前台服务用于用户希望系统立即执行或不中断的任务。 此类情况包括将照片上传到社交媒体,或者即使在音乐播放器应用不在前台运行时也能播放音乐。您不应该只是为了阻止系统判定您的应用处于闲置状态而启动前台服务。
应用生成用户可在锁定屏幕或通知栏中看到的通知。
应用是正在使用中的设备管理应用(例如设备政策控制器)。虽然设备管理应用通常在后台运行,但永远不会进入应用待机模式,因为它们必须保持可用性,以便随时从服务器接收策略。
当用户将设备插入电源时,系统会从待机状态释放应用,允许它们自由访问网络并执行任何待处理的作业和同步。如果设备长时间处于闲置状态,系统将允许闲置应用访问网络,频率大约每天一次。
在设备处于闲置状态时使用 FCM 与您的应用互动Firebase 云消息传递 (FCM) 是一项云端至设备服务,可让您支持后端服务与 Android 设备上的应用之间的实时下游消息传递。FCM 提供了一个到云的持久性连接,所有需要实时消息传递的应用均可共享此连接。此共享连接使多个应用不必保有自己的独立持久性连接,也就避免了快速耗尽电池电量,从而显著优化耗电情况。因此,如果您的应用需要与后端服务进行消息传递集成,我们强烈建议您尽可能使用 FCM,而不是保有自己的持久性网络连接。
FCM 经过优化,可通过高优先级 FCM 消息来支持低电耗模式和应用待机闲置模式。利用高优先级 FCM 消息,您可以可靠地唤醒应用以访问网络,即使用户的设备处于低电耗模式或应用处于应用待机模式也不例外。在低电耗模式或应用待机模式下,系统将传递消息并允许应用临时访问网络服务和部分唤醒锁定,然后将设备或应用恢复到闲置状态。
高优先级 FCM 消息不会影响低电耗模式,也不会影响任何其他应用的状态。这意味着您的应用可以使用这些消息来高效地通信,同时尽可能减小对整个系统和设备的电池影响。
作为一项常规最佳做法,如果您的应用需要下游消息传递,那么应使用 FCM。如果您的服务器和客户端已经在使用 FCM,请确保您的服务对关键消息使用高优先级消息,因为即使设备处于低电耗模式,这也会可靠地唤醒应用。
对其他用例的支持
通过妥善管理网络连接、闹钟、作业和同步以及使用高优先级 FCM 消息,几乎所有应用都应该能够支持低电耗模式。对于一小部分用例,这可能还不够。对于此类用例,系统提供了一个可配置的白名单,将部分免除低电耗模式和应用待机模式优化的应用列入其中。
在低电耗模式和应用待机模式期间,列入白名单的应用可以使用网络并保留部分唤醒锁定。不过,列入白名单的应用仍会受到其他限制,就像其他应用一样。例如,列入白名单的应用的作业和同步会延迟(在搭载 API 级别 23 及更低级别的设备上),并且其常规 AlarmManager
闹钟不会触发。应用可以调用 isIgnoringBatteryOptimizations()
来检查它当前是否在豁免白名单中。
用户可以依次转到设置 > 电池 > 电池优化来手动配置该白名单。另外,系统也提供了一些方法,让应用要求用户将其列入白名单。
应用可以触发
ACTION_IGNORE_BATTERY_OPTIMIZATION_SETTINGS
Intent,让用户直接转到电池优化,以便他们在其中添加该应用。具有
REQUEST_IGNORE_BATTERY_OPTIMIZATIONS
权限的应用可以触发一个系统对话框,让用户直接将该应用添加到白名单,而无需转到“设置”。此类应用将通过触发ACTION_REQUEST_IGNORE_BATTERY_OPTIMIZATIONS
Intent 来触发该对话框。用户可以根据需要从白名单中手动移除应用。
在要求用户将您的应用添加到白名单之前,请确保该应用符合列入白名单的可接受用例。
注意:除非应用的核心功能受到不利影响,否则 Google Play 政策禁止应用请求直接免除 Android 6.0 及更高版本中的电源管理功能(低电耗模式和应用待机模式)的制约。
在低电耗模式和应用待机模式下进行测试
为确保用户获得良好的体验,您应在低电耗模式和应用待机模式下全面测试您的应用。
在低电耗模式下测试您的应用
您可以按以下步骤在低电耗模式下测试您的应用:
使用 Android 6.0(API 级别 23)或更高版本的系统映像配置硬件设备或虚拟设备。
将设备连接到开发计算机并安装您的应用。
运行您的应用并使其保持活动状态。
运行以下命令,强制系统进入闲置模式:
准备就绪后,运行以下命令,使系统退出闲置模式:
执行以下命令,重新激活设备:
在重新激活设备后观察应用的行为。确保应用在设备退出低电耗模式时正常恢复。
在应用待机模式下测试您的应用
如需在应用待机模式下测试您的应用,请执行以下操作:
使用 Android 6.0(API 级别 23)或更高版本的系统映像配置硬件设备或虚拟设备。
将设备连接到开发计算机并安装您的应用。
运行您的应用并使其保持活动状态。
运行以下命令,强制应用进入应用待机模式:
使用以下命令模拟唤醒您的应用:
在唤醒应用后观察它的行为。确保应用从待机模式正常恢复。您应特别检查应用的通知和后台作业是否继续按预期运行。
列入白名单的可接受用例
下表重点介绍了请求将应用列入电池优化豁免白名单或应用目前在该白名单中的可接受用例。一般来说,除非低电耗模式或应用待机模式破坏了应用的核心功能,或者由于技术方面的原因而导致您的应用无法使用高优先级 FCM 消息,否则您的应用不应在白名单中。
评论