Osheep

时光不回头,当下最重要。

[译]图解Android应用的后台任务和提醒

原文:A flowchart for background work, alarms, and your Android app

《[译]图解Android应用的后台任务和提醒》

流程图

对于很多应用而言,构建后台任务是重要的一环。其中一种方式是:使用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支持单个和周期任务,缺少了唤醒沉睡设备的能力,但有能力等待网络接通,电池充电,利用自动退出和重试,重启机制和系统批量任务(意味着省电)。

有各种好理由说服你使用JobSchedulerGcmNetworkManager点这里构建更好的应用

推荐一个集大成的框架

点赞