в 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() вообще давно депрекейтед от греха.
Обсуждают сегодня