WorkManger学习汇总

一.使用

WorkManger主要是用来执行一定会执行的任务的,如即使app被杀掉、手机重启都会执行。

适用场景:定期重复性任务,如定期log上传等

使用的话首先引入库(我使用的是2.7.1)

Kotlin 复制代码
    implementation "androidx.work:work-runtime-ktx:2.7.1"

其次写个类继承Worker,重新doWork方法用来执行你的具体任务

Kotlin 复制代码
class TokenWorker(appContext: Context, workerParams: WorkerParameters) :
    CoroutineWorker(appContext, workerParams) {

    override suspend fun doWork(): Result = withContext(Dispatchers.IO) {
        try {
    
        } catch (e: Exception) {
            Result.failure()
        }
    }

}

然后在需要使用的地方,代码初始化workmanger并选用需要的方式开启任务

Kotlin 复制代码
    private val workManager: WorkManager by lazy {
        WorkManager.getInstance(applicationContext)
    }


        val constraints = Constraints.Builder()
            .setRequiredNetworkType(NetworkType.CONNECTED)
            .build()

        val tokenRefreshWorkRequest = PeriodicWorkRequestBuilder<TokenWorker>(50, TimeUnit.MINUTES)
            .setConstraints(constraints)
            .setInitialDelay(initialDelay, TimeUnit.MILLISECONDS)
            .addTag(tokenRefreshWorkName)
            .build()

        workManager.enqueueUniquePeriodicWork(
            tokenRefreshWorkName,
            ExistingPeriodicWorkPolicy.REPLACE,
            tokenRefreshWorkRequest
        )
我这里实现的是50分钟重复一次的任务,约束条件是网络连接以及app在前台的条件下

官网上也有很多使用实例可供参考学习

二.原理

1.WorkManger是在什么地方初始化的

当我们使用WorkManger时,会发现在生成的apk中provider子标签下有WorkManagerInitializer这个东西,这就是入口,同时发现有androidx.startup。

点进去发现继承自Initializer,和以前的版本不太一样了,以前看说是借助ContentProvider实现的,在 AndroidX Startup 之前,开发者通常会使用 ContentProvider 来在应用启动时初始化库。这是因为 ContentProvider 会在所有其他组件(如 Activity)之前创建和初始化。然而,这种方法有一些缺点,例如它会增加启动时间,并且使用 ContentProvider 可能会导致一些不必要的复杂性。AndroidX Startup 库提供了一种替代方案,可以避免这些问题。WorkManger就是更新了实现的方式。

复制代码
WorkManager.initialize(context, new Configuration.Builder().build())中就是创建的操作。最后发现实际上是WorkManagerImpl

通过WorkDatabse创建了任务列表并记录每一个任务的属性、执行条件顺序以及状态等,从而确保任务遭遇不测后(手机关机重启等),可以恢复继续执行

一路调用下来发现真正有作用的是internalInit方法,同时我们发现schedulers是GreedyScheduler

在ForceStopRunnable的run()方法中,我们发现它会完成那些被意外中断的任务。

以上就是WorkManger的初始化

2.dowork()

当我们在代码中通过各种方式调用enqueue()时,通过多种调用,最后都会走到WorkManagerImpl的startWork方法

最后发现StartWorkRunnable中run里面调用了startWork()方法

显然getProcessor是Processor,点进去继续看会发现

在runWorker()方法中我们发现startWork()

而startWork是Worker的方法并在里面执行doWork方法,这就是我们要继承Worker并重写doWork()方法的原因

相关推荐
ii_best4 小时前
按键精灵支持安卓14、15系统,兼容64位环境开发辅助工具
android
美狐美颜sdk4 小时前
跨平台直播美颜SDK集成实录:Android/iOS如何适配贴纸功能
android·人工智能·ios·架构·音视频·美颜sdk·第三方美颜sdk
恋猫de小郭8 小时前
Meta 宣布加入 Kotlin 基金会,将为 Kotlin 和 Android 生态提供全新支持
android·开发语言·ios·kotlin
aqi009 小时前
FFmpeg开发笔记(七十七)Android的开源音视频剪辑框架RxFFmpeg
android·ffmpeg·音视频·流媒体
androidwork11 小时前
深入解析内存抖动:定位与修复实战(Kotlin版)
android·kotlin
梦天201511 小时前
android核心技术摘要
android
szhangbiao13 小时前
“开发板”类APP如果做屏幕适配
android
塞尔维亚大汉13 小时前
鸿蒙内核源码分析(构建工具篇) | 顺瓜摸藤调试鸿蒙构建过程
源码·harmonyos
高林雨露14 小时前
RecyclerView中跳转到最后一条item并确保它在可视区域内显示
android
移动开发者1号16 小时前
ReLinker优化So库加载指南
android·kotlin