WorkManager PeriodicWorkRequest 运行 两次

WorkManager PeriodicWorkRequest run twice

我有一个每 15 分钟运行一次数据库刷新的应用程序。

PeriodicWorkRequest 在我的主 activity 的 onCreate 中排队。

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

    updateDatabasePeriodically();


public void updateDatabasePeriodically() {
    PeriodicWorkRequest updateDatabaseRequest =
            new PeriodicWorkRequest.Builder(UpdateDatabaseWorker.class, 15, TimeUnit.MINUTES).build();

    WorkManager.getInstance(getMainActivityContext()).enqueue(updateDatabaseRequest);
}

更新数据库工作者:

@Override
public Result doWork() {
    // Do the work here--in this case, upload the images.


    updateDatabase();
    // Indicate whether the task finished successfully with the Result
    return Result.success();
}

private void updateDatabase() {
    AppDatabase appDatabase = AppDatabase.getInstance(context);

    Log.i(TAG, "Updating alerts at: " + DateTimeHelper.getHumanReadableTime(now));
}

问题是每次作业执行时都会完成两次工作,从我的日志语句可以看出

2019-11-22 10:20:23.185 24987-25085/com.package.myapp I/com.package.myapp.UpdateDatabaseWorker: Updating at: 22/11/2019 10:20:23
2019-11-22 10:21:30.510 25309-25408/com.package.myapp I/com.package.myapp.UpdateDatabaseWorker: Updating at: 22/11/2019 10:21:30

2019-11-22 10:34:49.642 25309-26180/com.package.myapp I/com.package.myapp.UpdateDatabaseWorker: Updating at: 22/11/2019 10:34:49
2019-11-22 10:35:23.372 25309-26198/com.package.myapp I/com.package.myapp.UpdateDatabaseWorker: Updating at: 22/11/2019 10:35:23

为什么会这样?我应该在其他地方创建请求吗?

这是一个好的解决方案吗?

我觉得这是治标不治本

在这种情况下,请使用 uniqueWorkRequest,否则(尤其是对于 PeriodicWorkRequest)您将得到重复项。

public void updateDatabasePeriodically() {
    PeriodicWorkRequest updateDatabaseRequest =
            new PeriodicWorkRequest.Builder(UpdateDatabaseWorker.class, 15, TimeUnit.MINUTES).build();

    WorkManager.getInstance(getMainActivityContext())
        .enqueueUniquePeriodicWork("uniqueWorkName", 
                           ExistingPeriodicWorkPolicy.KEEP,
                           updateDatabaseRequest);
}

您可以查看 WorkManager#enqueueUniqueWork for more information on the call and on the ExistingPeriodicWorkPolicy 的参考,看看有哪些选项。

如果您没有使用 REPLACE 的要求,请使用 KEEP,它的成本更低,并且避免停止已经在工作的工作。