是的,你可以在周期性运行的Worker中传递输入数据。为此,你可以使用WorkerParameters.getInputData(),它将返回包含Worker创建时传入的所有数据的Data对象。
下面是一个示例,在此示例中,Worker将每隔15分钟运行一次,并打印传递给它的输入数据:
首先,我们定义一个Worker类:
public class MyWorker extends Worker { public static final String KEY_MY_DATA = "MY_DATA";
public MyWorker(@NonNull Context context, @NonNull WorkerParameters workerParams) {
super(context, workerParams);
}
@NonNull
@Override
public Result doWork() {
Data inputData = getInputData();
String myData = inputData.getString(KEY_MY_DATA);
// Do the work here and print the input data
Log.d("MyWorker", "Input Data: " + myData);
return Result.success();
}
}
然后,我们可以使用以下代码创建并执行Worker:
Constraints constraints = new Constraints.Builder() .setRequiredNetworkType(NetworkType.CONNECTED) .build();
PeriodicWorkRequest periodicWorkRequest = new PeriodicWorkRequest.Builder(MyWorker.class, 15, TimeUnit.MINUTES) .setInputData(new Data.Builder().putString(MyWorker.KEY_MY_DATA, "Hello WorkManager!").build()) .setConstraints(constraints) .build();
WorkManager.getInstance(context).enqueue(periodicWorkRequest);
在这个示例中,我们传递一个包含字符串“Hello WorkManager!”的Data对象给我们的Worker。然后我们使用WorkManager的enqueue()方法将定期请求添加到队列中。
现在,每隔15分钟,Worker将会执行,并从输入数据中读取“Hello WorkManager!”并将其打印出来。