Android WorkManager-应用程序终止后无法正常运行

时间:2019-02-04 12:18:42

标签: java android android-service alarmmanager android-workmanager

我创建了一个简单的workManager,我希望它在后台每隔1秒钟进行一次for循环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);
    }
}
}

这是我的MainActivity。

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秒后,循环又在后台开始。之后,当我打开应用程序时,循环将再次开始,而不会完成上一个循环。

例如,在后台循环中进行50次的25次迭代,如果我打开应用程序,日志将是这样的。

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

你看到了吗?打开应用程序2之后,循环开始异步迭代。 因此,第一个问题是如何避免这种情况发生(异步发生2个循环),第二个问题是为什么在销毁应用程序后我必须等待30-35秒才能在后台处理循环?谢谢。 我正在android 6.0中对此进行测试

在android 4.4中,后台任务根本没有调度。

1 个答案:

答案 0 :(得分:2)

此时您正在运行两个不同的worker副本-每次您的Activity启动时,您都在排队一个新的WorkRequest。如果您只想使用一份副本,请使用唯一的工作请求:https://developer.android.com/reference/androidx/work/WorkManager#enqueueUniqueWork(java.lang.String,%20androidx.work.ExistingWorkPolicy,%20androidx.work.OneTimeWorkRequest)