java - Android 中的 WorkManager Schedule_requested_at time 等于 -1。什么意思?

标签 java android worker android-workmanager stetho

我正在使用 WorkManager 来安排一些定期工作,以将本地数据库与远程数据库同步。几个月来一切都运行良好,直到有一天数据库停止了同步。我通过 Stetho 发现我所有的 Work 实例的“schedule_requested_at”值都等于 -1。

PeriodicWorkRequest refreshCpnWork = new PeriodicWorkRequest.Builder(MainWorker.class, Constants.WORKER_INTERVAL_MIN, TimeUnit.MINUTES)
    .addTag("PeriodicWork")
    .build();

WorkManager.getInstance().enqueue(refreshCpnWork);

These are the scheduled works, in normal conditions

这就是我安排工作的方式,正如我所说,几个月来效果很好。但从某个时刻开始,它停止安排我的工作,并且在图片中,不是正确的时间戳,而是 -1。

最佳答案

我发现schedule_requested_at中-1的含义是什么。

来自 WorkSpec.java(工作运行时:1.0.0-alpha11):

/**
 * This field tells us if this {@link WorkSpec} instance, is actually currently scheduled and
 * being counted against the {@code SCHEDULER_LIMIT}. This bit is reset for PeriodicWorkRequests
 * in API < 23, because AlarmManager does not know of PeriodicWorkRequests. So for the next
 * request to be rescheduled this field has to be reset to {@code SCHEDULE_NOT_REQUESTED_AT}.
 * For the JobScheduler implementation, we don't reset this field because JobScheduler natively
 * supports PeriodicWorkRequests.
 */
@ColumnInfo(name = "schedule_requested_at")
public long scheduleRequestedAt = SCHEDULE_NOT_REQUESTED_YET;

如果值为 -1,则工作已插入表中,但尚未安排。

在我的例子中,有太多的 Work 实例来安排新的内容,下面这个查询来自 WorkSpecDao.java:

/**
 * @return The List of {@link WorkSpec}s that are eligible to be scheduled.
 */
@Query("SELECT * FROM workspec WHERE "
        + "state=" + WorkTypeConverters.StateIds.ENQUEUED
        // We only want WorkSpecs which have not been previously scheduled.
        + " AND schedule_requested_at=" + WorkSpec.SCHEDULE_NOT_REQUESTED_YET
        + " LIMIT "
            + "(SELECT MAX(:schedulerLimit" + "-COUNT(*), 0) FROM workspec WHERE"
                + " schedule_requested_at<>" + WorkSpec.SCHEDULE_NOT_REQUESTED_YET
                + " AND state NOT IN " + COMPLETED_STATES
            + ")"
)
List<WorkSpec> getEligibleWorkForScheduling(int schedulerLimit);

关于java - Android 中的 WorkManager Schedule_requested_at time 等于 -1。什么意思?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56576777/

相关文章:

JAVA 正则表达式 :Make nested same values into single group

java - 在标准输出中打印数字的程序

java - 如何从 Android 应用程序强制连接到特定的 GSM 网络

amazon-web-services - 每种 Amazon 实例类型的适当 Gunicorn 工作人员数量是多少?

javascript - Web Worker/Canvas 内存泄漏

java - 查找字符串中最长的单词

java - 泛型行为在 JDK 8 和 9 中有所不同

Android Gradle 从 APK 中排除 jar

android - 在 android 上使用 Fresco 库显示来自 SD 卡的图像

ios - 卡住函数时 kotlin-native freeze() 方法崩溃