共计 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 有任何的问题或想法,请随时 提交到咱们公开的问题跟踪器 中。
欢迎您 点击这里 向咱们提交反馈,或分享您喜爱的内容、发现的问题。您的反馈对咱们十分重要,感谢您的反对!