WorkManager 在多进程应用中的高级用法-阿里云开发者社区

开发者社区> pcr5nnbbix3xm> 正文

WorkManager 在多进程应用中的高级用法

简介: 在 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,而是覆写 doRemoteWork,并在生成 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 发生的变更和改进的详细列表。

如果你想开发小程序或者了解小程序更多的内容,可以通过第三方专业开发平台,来帮助你实现开发需求:厦门在乎科技-专注厦门小程序开发公司、app开发、网站开发、H5小游戏开发

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
优雅的玩PHP多进程
proc_open (PHP 4 >= 4.3.0, PHP 5, PHP 7) proc_open — 执行一个命令,并且打开用来输入/输出的文件指针。 说明 ¶ resource proc_open ( string $cmd , array $descriptorspec , array &$pipes [, string$cwd [, array $env [, array $other_options ]]] ) 类似 popen() 函数, 但是 proc_open() 提供了更加强大的控制程序执行的能力。
940 0
2017云栖大会·杭州峰会:《在线用户行为分析:基于流式计算的数据处理及应用》Workshop-入口
2017云栖大会·杭州峰会:《在线用户行为分析:基于流式计算的数据处理及应用》Workshop-入口
3088 0
Shell多进程执行任务
管道就像水管,有流入才会有流出,水管数水流的通道,管道是数据的通道。管道分为无名管道和有名管道。 无名管道:常用的|就是管道,只不过是无名的,可以直接作为两个进程的数据通道,比如:cat file.txt | grep test 有名管道:mkfilo 可以创建一个管道文件,比如:mkfiflo testfifo 管道有一个特点,如果管道中没有数据,那么取管道数据的操作就会阻塞,直到管道内进入数据,然后读出后才会终止这一操作,同理,写入管道的操作如果没有读取操作,这一个动作也会阻塞。
822 0
UNIX环境高级编程笔记之进程控制
  本章重点介绍了进程控制的几个函数:fork、exec族、_exit、wait和waitpid等,主要需要掌握的是父进程和子进程之间的运行机制,怎么处理进程的正常和异常终止、以及怎么让进程执行不同的程序等知识点。下一章将进一步说明一个进程和其他进程之间的关系——会话和作业控制。
670 0
Palo Alto Networks推出云应用框架
本文讲的是 Palo Alto Networks推出云应用框架,下一代安全企业Palo Alto Networks近日宣布推出框架Palo Alto Networks应用框架,该框架以云为基础,可实现对Palo Alto Networks 下一代安全平台的功能扩展,助力客户快速购买和使用由各种规模供应商提供的广泛的云安全创新应用。
1288 0
+关注
pcr5nnbbix3xm
专注小程序、APP、网站开发
48
文章
11
问答
文章排行榜
最热
最新
相关电子书
更多
文娱运维技术
立即下载
《SaaS模式云原生数据仓库应用场景实践》
立即下载
《看见新力量:二》电子书
立即下载