android workmanager-应用程序终止后工作不好

fkaflof6  于 2021-07-09  发布在  Java
关注(0)|答案(1)|浏览(384)

我创建了简单的workmanager,我希望它在后台每1秒为循环工作50次,所以它将每1秒迭代一次循环并显示日志。首先让我介绍一下我的代码。
这是workmanager类。

public class WorkerClass extends Worker {

    private static String TAG = "work_tag";

    public WorkerClass(@NonNull Context context, @NonNull WorkerParameters workerParams) {
        super(context, workerParams);
    }

    @NonNull
    @Override
    public Result doWork() {
        try {
            loop();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return Result.success();
    }

    private void loop() throws InterruptedException {
        for (int i = 0; i < 50; i++) {
            Thread.sleep(1000);
            Log.d(TAG, "Working: " + i);
        }
    }
}

这是我的主要活动。

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        OneTimeWorkRequest oneTimeWorkRequest = new OneTimeWorkRequest.Builder(WorkerClass.class).build();

        WorkManager.getInstance().enqueue(oneTimeWorkRequest);
    }
}

如果有什么不对劲,请通知我。所以当我启动应用程序时,它会像这样每1秒显示一次日志。

D/work_tag: Working: 1
D/work_tag: Working: 2
D/work_tag: Working: 3
D/work_tag: Working: 4
D/work_tag: Working: 5

好吧是吗?因此,当我杀死应用程序(ondestroy)时,30-35秒后,循环在后台再次开始。之后,当我打开应用程序时,循环再次开始,而没有完成上一个循环。
例如,在后台循环迭代了25次50,如果我打开应用程序,日志会是这样的。

D/work_tag: Working: 25
D/work_tag: Working: 0
D/work_tag: Working: 26
D/work_tag: Working: 1
D/work_tag: Working: 27
D/work_tag: Working: 2
D/work_tag: Working: 28
D/work_tag: Working: 3
D/work_tag: Working: 29
D/work_tag: Working: 4

你看到了吗?打开app2后,循环开始异步迭代。所以第一个问题是如何避免这种情况发生(2个异步循环),第二个问题是为什么在销毁应用程序后,我必须等待30-35秒才能在后台运行循环?
我正在android6.0中测试这个
在android4.4中,后台任务根本没有调度。

mf98qq94

mf98qq941#

此时您正在运行两个不同的worker副本—每次活动启动时,您都在排队等待一个新的workrequest。如果只想使用一个副本,请使用唯一的工作请求:https://developer.android.com/reference/androidx/work/workmanager#enqueueuniquework(java.lang.string,%20androidx.work.existingworkpolicy,%20androidx.work.onetimeworkrequest)

相关问题