当应用程序已经重新启动时,WorkerManger 仍然是自动 运行
WorkerManger is still auto running when app has already restarted
我发现当worker在app上运行然后强行关闭,之后我重新打开app,但是worker还是自动从后台重新运行没有我的控制...
我怎样才能避免这个问题?我怎样才能取消这个工作人员?
val work = OneTimeWorkRequest
.Builder(DownloadImageWorker::class.java)
.build()
WorkManager.getInstance(App.instance)
.beginWith(work).enqueue()
WorkManager 用于需要保证为 运行 的任务。您描述的行为是 as designed.
如果您不需要像 Kotlin 的协程那样以这种方式持久化任务,您可能想要评估其他解决方案。您可以在 Android's background guide.
上找到更多信息
WorkManager 的一个选项是手动取消您的 WorkRequest。从您的代码开始:
val work = OneTimeWorkRequest
.Builder(DownloadImageWorker::class.java)
.build()
val workManager = WorkManager.getInstance(App.instance)
workManager.beginWith(work).enqueue()
然后您可以在需要时取消工作请求:
// Cancel the WorkRequest
workManager.cancelWorkById(work.id)
您可以在 WorkManager's documentation 上找到更多信息。
我发现当worker在app上运行然后强行关闭,之后我重新打开app,但是worker还是自动从后台重新运行没有我的控制...
我怎样才能避免这个问题?我怎样才能取消这个工作人员?
val work = OneTimeWorkRequest
.Builder(DownloadImageWorker::class.java)
.build()
WorkManager.getInstance(App.instance)
.beginWith(work).enqueue()
WorkManager 用于需要保证为 运行 的任务。您描述的行为是 as designed.
如果您不需要像 Kotlin 的协程那样以这种方式持久化任务,您可能想要评估其他解决方案。您可以在 Android's background guide.
上找到更多信息WorkManager 的一个选项是手动取消您的 WorkRequest。从您的代码开始:
val work = OneTimeWorkRequest
.Builder(DownloadImageWorker::class.java)
.build()
val workManager = WorkManager.getInstance(App.instance)
workManager.beginWith(work).enqueue()
然后您可以在需要时取消工作请求:
// Cancel the WorkRequest
workManager.cancelWorkById(work.id)
您可以在 WorkManager's documentation 上找到更多信息。