26

Google 最近弃用了 IntentService:https ://android.googlesource.com/platform/frameworks/base.git/+/6f8b09029932dfd24945202017639754b00acc2e

IntentService 的文档现在说:

 * @deprecated IntentService is subject to all the
 *   <a href="/preview/features/background.html">background execution limits</a>
 *   imposed with Android 8.0 (API level 26). Consider using {@link androidx.work.WorkManager}
 *   or {@link androidx.core.app.JobIntentService}, which uses jobs
 *   instead of services when running on Android 8.0 or higher.

那么 JobIntentService 和 WorkManager 有什么区别,在什么情况下推荐使用哪一个呢?

谷歌甚至没有在这个页面上提到 JobIntentService,他们只提到了 WorkManager:https ://developer.android.com/guide/background

4

1 回答 1

41

由于 Android Oreo 我们不能再让正常的服务在后台运行,因为系统会:

1-如果应用程序本身在启动服务后进入后台,大约一分钟后终止服务

2-如果应用程序本身在后台时启动服务,则抛出异常

IntentService 只是普通服务的一个子类,它在后台线程上按顺序执行所有工作,并在完成所有工作时自行停止。但作为一项服务,它也受到上述限制的影响。

现在对于 JobIntentService:

将在 Pre-Oreo 设备上充当普通 IntentService(因为我们没有任何限制),并且在 Oreo+ 上将使用 jobScheduler 来实现与 IntentService 类似的行为。它只是尽快开始工作,通过 JobScheduler 安排其工作,并且 JobScheduler 可能会选择将该工作推迟一点,但它的工作更有可能在低内存情况下,在打盹模式下或当他们达到了时间限制(〜10分钟)

使用 JobIntentService,做一些配置是不可能的,比如明确定义我们希望我们的工作在什么情况下开始(例如设备当前正在充电或者我们是否有 WIFI 连接),但是使用 workmanager 我们可以设置这些约束。

将 WorkManager 用于具有某些约束的作业,或用于事务性不正在进行的作业/工作,或用于可能在未来某个时间发生的作业,并在您想要复制 Android Oreo+ 上的正常 IntentService 的行为时使用 JobIntentService 和可能会稍微延迟并且可能需要超过 1 分钟但不到 10 分钟的作业。

希望我回答了你的问题。

问候

于 2020-01-14T02:51:38.637 回答