何时使用 JobIntentService 与 WorkManager?

sat*_*ine 23 android jobintentservice android-workmanager

谷歌最近弃用了 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.
Run Code Online (Sandbox Code Playgroud)

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

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

小智 35

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

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

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

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

现在对于 JobIntentService:

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

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

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

希望我回答了你的问题。

问候

  • JobIntentService 已被弃用... (6认同)