原文:A flowchart for background work, alarms, and your Android app
流程图对于很多应用而言,构建后台任务是重要的一环。其中一种方式是:使用AlarmManager
注册定时器唤醒未在前台启动的应用(例如闹钟,译者注)。如何优雅低使用定时器类和API,它们是不是你的最佳选择?下面让我们看看如何抉择。
唤醒频率?
对于少于60秒的唤醒,定时器类并不是最优解:使用更高效的的Handler
来处理频发的任务。
希望用户看到计时?
对于API21+
(Android5.0以上,译者注),新API
允许使用setAlarmClock()
方法来设置一个可见的定时器:系统UI通过getNextAlarmClock()
更新时间和图标。注意setAlarmClock()
可以在设备/应用休眠时生效(类似于setExactAndAllowWhileIdle()
):更形象的描述是类似来电唤醒。为了向后兼容,你可以继续往下看。
休眠唤醒(例如,待机应用)?
在Android 6.0+(API 23),休眠模式下新增了休眠模式(在完全静止,不充电,闲置时启动)和应用待机模式(不充电,未使用一段时间)。偷懒可以调用setAndAllowWhileIdle()
或者精准调用setExactAndAllowWhileIdle()
来唤醒上述空闲状态。为了完全符合Android标准和节省电量,使用标准的set()
和setExact()
方法等到用户打开你的应用后再提醒。
(我们已后会继续深入讨论休眠模式和应用待机模式!)
只是唤醒?
单个定时器可以恰当地使用set()
方法设置,需要注意的是,这个方法并不准确,当目标##Android API版本大于或等于19,可能与批量定时器一样——在到达结束时间点前,计时器并不会休眠,但时间结束后进入休眠。如果对于开始时间比较宽松,结束时间比较严格,考虑使用setWindow()
**加强对准确时间段的控制。
在Android API 19+使用setExact()
设置精确的定时器,只有在需要精准时刻的时候使用(例如日历提醒器)
需要以固定频率重复?
对于反复定时器,批量是一个好的省电策略。
setInexactRepeating()
正是实现的好方法。API 19
以前,可以使用常量INTERVAL_
(例如,INTERVAL_HOUR
实现批量固定间隔的定时器)。对于API 19+
的设备,所有重复的定时器(无论是否设置了INTERVAL_
),只要设置**setInexactRepeating()
都会成为批量定时器。
如果细心观察,会发现setRepeating()
——类似set()
,从API 19开始,就成为不精确的重复。也就是说,在大于等于API 19的设备上,setRepeating()
会调用setInexactRepeating()
。如果真的需要精确,使用setExact()
,在唤醒成功之后再次设置定时器。记得考虑电量情况!
等一等,真的需要定时?
如果真的想省电,在API 21+考虑使用JobScheduler
,或者在Android API9而且Google Service
全开时使用GcmNetworkManager
(嗯,天朝自动忽略,译者注)
上述API支持单个和周期任务,缺少了唤醒沉睡设备的能力,但有能力等待网络接通,电池充电,利用自动退出和重试,重启机制和系统批量任务(意味着省电)。
有各种好理由说服你使用JobScheduler
和GcmNetworkManager
,点这里构建更好的应用
网友评论