в Worker, потом в логе вижу Exception,
Work [ id=4a653df1-c1ab-4fce-a0a1-675c24f964e6, tags={ .drive.workers.BuildCompleteDriveReportWorker, scan_tag, primary } ] was cancelled
java.util.concurrent.CancellationException: Task was cancelled.
at androidx.work.impl.utils.futures.AbstractFuture.cancellationExceptionWithCause(AbstractFuture.java:1184)
at androidx.work.impl.utils.futures.AbstractFuture.getDoneValue(AbstractFuture.java:514)
at androidx.work.impl.utils.futures.AbstractFuture.get(AbstractFuture.java:475)
at androidx.work.impl.WorkerWrapper$2.run(WorkerWrapper.java:311)
at androidx.work.impl.utils.SerialExecutor$Task.run(SerialExecutor.java:91)
at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1167)
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:641)
at java.lang.Thread.run(Thread.java:920),
но задача не останавливается, о чем свидетельсвует попытка опубликовать прогресс W/WM-WorkProgressUpdater: Ignoring setProgressAsync(...). WorkSpec (4a653df1-c1ab-4fce-a0a1-675c24f964e6) is not in a RUNNING state.
Вопрос, как правильно остановить выполняющийся worker?
UPDATE: параллельно в doWork выполняется тяжелая задача и нет механизма ее остановить, кроме как убить воркер
Никак? В jvm очень плохо с принудительной остановкой выполняющегося даже в отдельном потоке задания - хочешь его остановить, выстави там флаг типа canceled и проверяй, флаг выставлен - тормози тяжелую задачу. это типовой подход из java threads. Можно вызвать для потока интеррапт и там тормознуть задачу. Java Thread.stop() вообще давно депрекейтед от греха.
Обсуждают сегодня