• WorkManager的学习三


    一、前言

    本篇记录下WorkManager的进度观察和多个Work链接的内容。

    二、监听进度

    WorkManager提供对进度的观察,示例如下:

    更新进度:

    import android.content.Context
    import androidx.work.CoroutineWorker
    import androidx.work.Data
    import androidx.work.WorkerParameters
    import kotlinx.coroutines.delay
    
    class ProgressWorker(context: Context, parameters: WorkerParameters) :
        CoroutineWorker(context, parameters) {
    
        companion object {
            const val Progress = "Progress"
            private const val delayDuration = 1L
        }
    
        override suspend fun doWork(): Result {
            val firstUpdate = workDataOf(Progress to 0)
            val lastUpdate = workDataOf(Progress to 100)
            setProgress(firstUpdate)
            delay(delayDuration)
            setProgress(lastUpdate)
            return Result.success()
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23

    观察进度:

    WorkManager.getInstance(applicationContext)
        // requestId is the WorkRequest id
        .getWorkInfoByIdLiveData(requestId)
        .observe(observer, Observer { workInfo: WorkInfo? ->
                if (workInfo != null) {
                    val progress = workInfo.progress
                    val value = progress.getInt(Progress, 0)
                    // Do something with progress information
                }
        })
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10

    需要注意的是,getWorkInfoById()在实际测试中无法监听进度,暂时原因未知。而且仅会在任务开始时候执行一次,其后就不再执行,所以倘若任务延迟后,那么可能获取不到实际的结果。

    三、链接工作

    WorkManager在实际工作中允许将多个Work进行链接,进行并发或者顺序执行。

    如需创建工作链,您可以使用 WorkManager.beginWith(OneTimeWorkRequest)WorkManager.beginWith(List<OneTimeWorkRequest>),这会返回 WorkContinuation 实例。

    然后,可以使用 WorkContinuation 通过 then(OneTimeWorkRequest)then(List<OneTimeWorkRequest>) 添加 OneTimeWorkRequest 依赖实例。 .

    每次调用 WorkContinuation.then(...) 都会返回一个新的 WorkContinuation 实例。如果添加了 OneTimeWorkRequest 实例的 List,这些请求可能会并行运行。

    最后,您可以使用 WorkContinuation.enqueue() 方法对 WorkContinuation 工作链执行 enqueue() 操作。

    
    WorkManager.getInstance(myContext)
       // Candidates to run in parallel
       .beginWith(listOf(plantName1, plantName2, plantName3))
       // Dependent work (only runs after all previous work in chain)
       .then(cache)
       .then(upload)
       // Call enqueue to kick things off
       .enqueue()
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9

    四、输入合并

    WorkManager的链式调用中,每一次的工作结果都会成为下一个工作的输入内容。为了管理这种事情,WorkManager使用 InputMerger来处理这种事情。

    WorkManager 提供两种不同类型的 InputMerger

    如果您有更具体的用例,则可以创建 InputMerger 的子类来编写自己的用例

    示例代码如下:

    
    val cache: OneTimeWorkRequest = OneTimeWorkRequestBuilder<PlantWorker>()
       .setInputMerger(ArrayCreatingInputMerger::class)
       .setConstraints(constraints)
       .build()
    
    • 1
    • 2
    • 3
    • 4
    • 5

    五、参考链接

    1. https://developer.android.google.cn/topic/libraries/architecture/workmanager/how-to/chain-work
  • 相关阅读:
    zynq soc 计划
    L1-012 计算指数 C++
    第二篇------Virtual I/O Device (VIRTIO) Version 1.1
    mysql某批量更新导致死锁
    说说原型(prototype)、原型链
    PLC中ST编程的星角降压启动
    HBase与Hive集成
    关于主表和子表数据的保存
    若依微服务版的快速构建
    ActiveMQ、RabbitMQ、RocketMQ、Kafka介绍
  • 原文地址:https://blog.csdn.net/Mr_Tony/article/details/125615450