我是JobDispatcher的新手,所以我不太确定我的问题是否有意义。
我有一个要求,我需要在后台定期运行一些任务(即使应用程序未运行(。 任务未在固定的时间间隔内执行。第一次执行任务时,我会了解下一个任务执行的调度,所以第一次执行后,我应该将相同的任务重新调度到以后的下一次,我会 完成任务后了解。事情就这样继续下去。
这就像从网络同步某些内容,网络数据将告诉下一步何时同步。
所以,我的问题是
我是否应该每次为每个新任务创建一个新作业?
我可以创建重复作业并继续更改间隔吗?
我如何使用FireBaseJobDispatcher完全处理这种情况。
我选择了FireBaseJobDispatcher而不是JobScheduler,因为我的应用程序也必须支持Lollipop以下。
这是我尝试使用FireBaseJobDispatcher在给定时间执行任务的示例代码,并且工作正常。现在我陷入了如何将其重新安排到下一个同步时间的问题。
public class MyJobService extends JobService {
private static final String TAG = "MyJobService";
@Override
public boolean onStartJob(final JobParameters job) {
// Do some work here
Log.d(TAG, "onStartJob: at "+Thread.currentThread().getName());
new Thread(new Runnable() {
@Override
public void run() {
Log.d(TAG, "run: startign job ");
try {
Thread.sleep(2000);
// some syncing operation
} catch (InterruptedException e) {
e.printStackTrace();
}
Log.d(TAG, "run: job done");
// here I need to reschedule the same job to a future time
}
}).start();
return false;
}
@Override
public boolean onStopJob(JobParameters job) {
Log.d(TAG, "onStopJob: ");
return false;
}
}
我在活动中设置作业是这样的
// Create a new dispatcher using the Google Play driver.
FirebaseJobDispatcher dispatcher = new FirebaseJobDispatcher(new GooglePlayDriver(this));
Bundle myExtrasBundle = new Bundle();
myExtrasBundle.putString("some_key", "some_value");
Job myJob = dispatcher.newJobBuilder()
.setService(MyJobService.class)
.setTag("syncservice")
.setRecurring(true)
.setLifetime(Lifetime.FOREVER)
.setTrigger(Trigger.executionWindow(1*60*60 , 1*60*60)) // rigger after an hour
// don't overwrite an existing job with the same tag
.setReplaceCurrent(false)
// retry with exponential backoff
.setRetryStrategy(RetryStrategy.DEFAULT_EXPONENTIAL)
.setConstraints(
Constraint.ON_ANY_NETWORK
)
.setExtras(myExtrasBundle)
.build();
dispatcher.mustSchedule(myJob);
提前感谢!
@Override
public boolean onStopJob(JobParameters job) {
Log.d(TAG, "onStopJob: ");
if(rescheduleJob)
return true; // reschedule job
else
return false; // cancel job
}
或者你可以试试:
@Override
public boolean onStopJob(JobParameters job) {
Log.d(TAG, "onStopJob: ");
return rescheduleJob;
}