WorkManager 在 Android 开发中的 10 个典型应用场景,涵盖不同业务需求和技术特性:
- 用户行为日志批量上传 • 场景:收集用户操作日志(如点击事件、页面浏览),每隔 6 小时批量压缩并上传至服务器。
• Why WorkManager:
• 周期性任务(PeriodicWorkRequest
)自动触发。
• 添加 NetworkType.UNMETERED
约束,仅在 Wi-Fi 环境下上传,节省用户流量。
kotlin
val logUploadWork = PeriodicWorkRequestBuilder<LogUploadWorker>(6, TimeUnit.HOURS)
.setConstraints(Constraints.Builder().setRequiredNetworkType(NetworkType.UNMETERED).build())
.build()
WorkManager.getInstance(context).enqueue(logUploadWork)
- 应用缓存定期清理 • 场景:每周自动清理临时缓存文件(如图片缩略图、临时下载文件)。
• Why WorkManager:
• 周期性任务确保长期维护存储空间。
• 设置 RequiresDeviceIdle
约束,避免干扰用户使用。
kotlin
val cleanCacheWork = PeriodicWorkRequestBuilder<CleanCacheWorker>(7, TimeUnit.DAYS)
.setConstraints(Constraints.Builder().setRequiresDeviceIdle(true).build())
.build()
- 离线任务队列处理 • 场景:用户无网络时提交的表单数据,在恢复网络后自动重试提交。
• Why WorkManager:
• 使用 OneTimeWorkRequest
持久化存储任务。
• 依赖 NetworkType.CONNECTED
约束,确保网络可用时执行。
kotlin
val retrySubmitWork = OneTimeWorkRequestBuilder<SubmitFormWorker>()
.setConstraints(Constraints.Builder().setRequiredNetworkType(NetworkType.CONNECTED).build())
.build()
WorkManager.getInstance(context).enqueue(retrySubmitWork)
- 定时推送本地通知(如健康提醒) • 场景:每天上午 9 点提醒用户喝水或记录健康数据。
• Why WorkManager:
• 结合 AlarmManager
的精确时间触发(通过 setInitialDelay
计算时间差)。
• 即使应用关闭,任务依然可靠执行。
kotlin
val delay = calculateDelayUntil9AM() // 计算到次日 9 点的延迟时间
val reminderWork = OneTimeWorkRequestBuilder<ReminderWorker>()
.setInitialDelay(delay, TimeUnit.MILLISECONDS)
.build()
- 图片/视频后台压缩 • 场景:用户上传高清图片时,在后台压缩为指定分辨率并保留原图。
• Why WorkManager:
• 通过 Worker
在后台线程执行 CPU 密集型操作。
• 添加 BatteryNotLow
约束,避免低电量时耗电。
kotlin
val compressWork = OneTimeWorkRequestBuilder<ImageCompressWorker>()
.setConstraints(Constraints.Builder().setRequiresBatteryNotLow(true).build())
.build()
- 依赖网络的内容预加载 • 场景:在用户连接 Wi-Fi 且设备充电时,预加载次日新闻内容。
• Why WorkManager:
• 多约束组合:NetworkType.UNMETERED
+ RequiresCharging
。
• 通过链式任务实现"下载 → 解析 → 缓存"。
kotlin
val downloadWork = OneTimeWorkRequestBuilder<DownloadNewsWorker>().build()
val parseWork = OneTimeWorkRequestBuilder<ParseNewsWorker>().build()
WorkManager.getInstance(context)
.beginWith(downloadWork)
.then(parseWork)
.enqueue()
- 用户行为埋点聚合上报 • 场景:收集用户埋点事件(如按钮点击),每隔 30 分钟聚合后批量上报。
• Why WorkManager:
• 周期性任务减少频繁网络请求。
• 使用 Data
类传递聚合数据给 Worker。
kotlin
val analyticsWork = PeriodicWorkRequestBuilder<AnalyticsWorker>(30, TimeUnit.MINUTES)
.setInputData(Data.Builder().putString("events", jsonData).build())
.build()
- 应用配置动态更新 • 场景:每天检查服务端配置(如功能开关、AB 测试参数),更新本地缓存。
• Why WorkManager:
• 周期性任务确保配置及时性。
• 网络约束避免无效请求。
kotlin
val configUpdateWork = PeriodicWorkRequestBuilder<ConfigUpdateWorker>(1, TimeUnit.DAYS)
.setConstraints(Constraints.Builder().setRequiredNetworkType(NetworkType.CONNECTED).build())
.build()
- 数据库备份与恢复 • 场景:每周日凌晨 3 点备份 SQLite 数据库到云端。
• Why WorkManager:
• 精确时间控制(通过 setInitialDelay
)。
• 依赖 DeviceIdle
减少性能影响。
kotlin
val backupWork = OneTimeWorkRequestBuilder<BackupWorker>()
.setInitialDelay(calculateDelayToNextSunday3AM())
.setConstraints(Constraints.Builder().setRequiresDeviceIdle(true).build())
.build()
- 应用安装后首次初始化 • 场景:用户安装应用后,在后台初始化本地数据库、下载必要资源。
• Why WorkManager:
• 使用 WorkManager
的 UniqueWork
避免重复初始化。
• 任务优先级设置为 HIGH
,加速用户体验。
kotlin
val initWork = OneTimeWorkRequestBuilder<InitWorker>()
.setExpedited(OutOfQuotaPolicy.DROP_WORK_REQUEST) // 高优先级(Android 12+)
.build()
WorkManager.getInstance(context)
.enqueueUniqueWork("init_work", ExistingWorkPolicy.REPLACE, initWork)
核心原则
- 延迟任务:优先保证用户体验,避免主线程阻塞。
- 资源友好:通过约束(网络、电量、设备状态)减少系统负担。
- 可靠性:任务持久化存储,即使应用被终止或设备重启也能恢复。
- 合规性:遵循 Android 后台限制政策(如避免过度唤醒)。