关于android:WorkManager-在多进程应用中的高级用法

4次阅读

共计 1626 个字符,预计需要花费 5 分钟才能阅读完成。

在 WorkManager 2.5 中,咱们让多过程利用可能更容易地拜访在指定过程中运行的特定 WorkManager 实例。

当初,咱们更是在 WorkManager 2.6 中进一步减少了可能让 Worker 在任意过程中运行的反对,并且能将 Worker 绑定到指定的过程。多过程反对对于须要在多个过程中运行 Worker 的利用十分有用。尽管大多数利用只须要一个过程就能良好地工作,但有些利用则须要多个过程来实现它们的工作,这在过来很难治理不同过程之间的工作,但当初所有都不一样了!

从 WorkManager 2.6 开始,您能够应用 RemoteListenableWorker 或 RemoteCoroutineWorker 将 Worker 绑定到特定过程。如果您应用 Kotlin 来实现 Worker,请应用 RemoteCoroutineWorker,而其余状况则应用 RemoteListenableWorker。在本文中咱们的示例将应用 Kotlin 来实现,咱们也在上面的示例链接中提供了类似的 Java 实现。

RemoteCoroutineWorker 实现起来和 CoroutineWorker 很相像,但不必覆写 doWork,而是覆写 do**Remote**Work,并在生成 WorkRequest 时将 ARGUMENT_CLASS_NAME 和 ARGUMENT_PACKAGE_NAME 两个参数传入 InputData 来将其绑定到特定过程。

val PACKAGE_NAME = "com.example.background.multiprocess"

// RemoteWorkerService 被增加到利用的 AndroidManifest.xml
val serviceName = RemoteWorkerService::class.java.name
val componentName = ComponentName(PACKAGE_NAME, serviceName)

val data: Data = Data.Builder()
   .putString(ARGUMENT_PACKAGE_NAME, componentName.packageName)
   .putString(ARGUMENT_CLASS_NAME, componentName.className)
   .build()

return OneTimeWorkRequestBuilder<ExampleRemoteCoroutineWorker>
   .setInputData(data)
   .build()

而后您须要像这样为每个 RemoteWorkerService 在 AndroidManifest 中增加 service 定义:

<manifest ... >
    <service
            android:name="androidx.work.multiprocess.RemoteWorkerService"
            android:exported="false"
            android:process=":worker1" />

    <!-- RemoteWorkerService2 extends RemoteWorkerService -->    
    <service
            android:name=".RemoteWorkerService2"
            android:exported="false"
            android:process=":worker2" />
    ...
</manifest>

您能够在新的 WorkManager 多过程示例 中理解这些新性能如何工作,它同时应用 RemoteCoroutineWorker 和 RemoteListenableWorker 实现。

您还能够在咱们的 公布阐明 中看到在 WorkManager 2.6 产生的变更和改良的具体列表。

最初,如果您对于 WorkManager 有任何的问题或想法,请随时 提交到咱们公开的问题跟踪器 中。

欢迎您 点击这里 向咱们提交反馈,或分享您喜爱的内容、发现的问题。您的反馈对咱们十分重要,感谢您的反对!

正文完
 0