- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我之前使用的是 GCM 网络管理器,但后来听说 Firebase JobDispatcher 包括 GCM 以及其他功能,所以我尝试使用它。我已经成功地编写了一个周期性任务并且它工作正常,但问题是我需要改变周期而不是从一开始就固定。
这样做的原因是,我正在使用 Activity 识别服务,我希望 JobDispatcher 下次执行周期性任务时基于检测到的当前 Activity 。比如你在走路,下一次触发任务是在30分钟后,而如果你在车里,那么这个时间段是5分钟(主要是因为如果你在车里,你的手机更有可能将在短时间内提供与步行时不同的位置值)。
这是我对周期性任务进行编程的方式,如您所见,我设置了一个固定值,我想知道由此任务触发的服务是否可以提供反馈,从而改变周期性任务任务。
final Builder builder = jobDispatcher.newJobBuilder()
.setTag(form.tag.get())
.setRecurring(form.recurring.get())
.setLifetime(form.persistent.get() ? Lifetime.FOREVER : Lifetime.UNTIL_NEXT_BOOT)
.setService(DemoJobService.class)
.setTrigger(Trigger.executionWindow(
form.getWinStartSeconds(), form.getWinEndSeconds()))
.setReplaceCurrent(form.replaceCurrent.get())
.setRetryStrategy(jobDispatcher.newRetryStrategy(
form.retryStrategy.get(),
form.getInitialBackoffSeconds(),
form.getMaximumBackoffSeconds()));
if (form.constrainDeviceCharging.get()) {
builder.addConstraint(Constraint.DEVICE_CHARGING);
}
if (form.constrainOnAnyNetwork.get()) {
builder.addConstraint(Constraint.ON_ANY_NETWORK);
}
if (form.constrainOnUnmeteredNetwork.get()) {
builder.addConstraint(Constraint.ON_UNMETERED_NETWORK);
}
最佳答案
为此,您需要使用保存在 SharedPrefs/其他地方的标签( form.tag.get()
在你的例子中):
FirebaseJobDispatcher(GooglePlayDriver(context)).cancel(yourTag)
然后它可以使用更新后的参数重新安排作业。很遗憾,目前无法编辑作业,必须取消并重新创建!
关于android - 更改 Firebase JobDispatcher 中周期性任务的周期?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42495966/
我已经完成了创建和启动计时器的手册页。 http://man7.org/linux/man-pages/man2/timerfd_create.2.html 但是,除了 arm(start) 和 di
我正在用 opengl 编写新的代码库,很早就遇到了一个奇怪的错误。这是帧速率的明显波动,具有重复性和可预测性。 我知道它肯定与渲染的对象成正比。它也与屏幕大小成正比(不是视口(viewport)大小
我知道如何使用计算数组中点之间的欧几里得距离 scipy.spatial.distance.cdist 类似于这个问题的答案: Calculate Distances Between One Poin
我想使用 CGAL 构造周期性 3D Delaunay 三角剖分和信息(在本例中为整数)。对于 2D,如果我构造一个 vector 对(点,信息)并将其传递给三角测量函数,则效果很好。然而,非常类似的
每隔几天,我们就会收到少量 MySql 超时错误,这些错误与我们的 MySQL RDS 实例上的 CPU 和数据库连接出现大量峰值相对应。这些查询通常非常快(<5 毫秒),但突然超时。 此时,数据库操
我是一名优秀的程序员,十分优秀!