猿问

Android WorkManager:无法从PeriodicWorkRequest获取输出数据

由于某些原因,我无法从 Android WorkManager 的PeriodicWorkRequest 获取输出数据。工作线程按预期定期运行,只是不返回任何数据。


我的主要活动:


@Override

protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);

    setContentView(R.layout.activity_main);

    schedulePeriodicRequests();

}


public void schedulePeriodicRequests() {

    PeriodicWorkRequest workRequest = new PeriodicWorkRequest.Builder(ServerRequestsWorker.class, 15, TimeUnit.MINUTES)

            .build();


    WorkManager workManager = WorkManager.getInstance(MainActivity.this);

    workManager.enqueue(workRequest);

    workManager.getWorkInfoByIdLiveData(workRequest.getId())

            .observe(this, new Observer<WorkInfo>() {

                @Override

                public void onChanged(@Nullable WorkInfo workInfo) {

                    if (workInfo != null) {

                        Log.d(LOG_TAG, "WorkInfo received: state: " + workInfo.getState());

                        String message = workInfo.getOutputData().getString(ServerRequestsWorker.KEY_MESSAGE);

                        Log.d(LOG_TAG, "message: " + message);

                    }

                }

            });

}

我的服务器请求工作人员:


public static final String KEY_MESSAGE = "message";


@NonNull

@Override

public Result doWork() {

    Log.d(LOG_TAG, "Worker works");


    Data outputData = new Data.Builder()

            .putString(KEY_MESSAGE, "This is output message")

            .build();


    return Result.success(outputData);

}


,然后我成功收到输出数据的值:


MainActivity: message: This is output message

我尝试过将独特的工作排队并按标签排队,但没有运气。尝试过WorkManager 2.2.0和1.x,结果是一样的。


我错过了什么吗?是否有可能从PeriodicWorkRequest 获取输出数据?我有什么错吗?


慕盖茨4494581
浏览 167回答 2
2回答

一只甜甜圈

根据WorkInfo文档:请注意,输出仅适用于终端状态(WorkInfo.State.SUCCEEDED和WorkInfo.State.FAILED)。对于定期工作,每次运行都会重复使用相同的 ID,这意味着工作永远不会到达SUCCEEDED- 相反,工作会立即转换回ENQUEUED,等待下一次定期运行。因此,您所经历的似乎是预期的行为。正如您所看到的,使用一次性工作不会出现这种行为,因为工作实际到达SUCCEEDED并且每次后续运行(如果您的一次性工作要重新安排相同类型的工作)都会有一个新的 ID。另一种选择是不使用输出数据,而是将定期工作的结果存储在您自己的数据库中。

胡说叔叔

另一种选择是观察中间 Worker 进度在您的 ServerRequestsWorker 中:        val outputProgress = workDataOf(KEY_MESSAGE to "This is progress message")        setProgress(outputProgress)然后在你的 MainActivity 中:workManager.getWorkInfoByIdLiveData(workRequest.getId())        .observe(this, new Observer<WorkInfo>() {            @Override            public void onChanged(@Nullable WorkInfo workInfo) {                if (workInfo != null) {                    Log.d(LOG_TAG, "WorkInfo received: state: " + workInfo.getState());                    String message = workInfo.getProgress().getString(ServerRequestsWorker.KEY_MESSAGE);                    Log.d(LOG_TAG, "message: " + message);                }            }        });
随时随地看视频慕课网APP

相关分类

Java
我要回答