我正在创建一个Android应用程序以在后台运行我的代码。我很清楚Android Oreo为后台服务引入的限制,这就是为什么我使用WorkManager API安排执行任务的原因。我正在使用Android API 24(牛轧糖)在Mi Max设备上测试我的代码,并且还手动启用了自动启动,以便MIUI允许应用程序在后台运行,但是问题是,WorkManager会在应用程序首次启动时触发,在那之后,它不起作用。下面是我用于定期工作请求和工作本身的代码。
PeriodicWorkRequest调用:
PeriodicWorkRequest work = new PeriodicWorkRequest.Builder(ClassExtendingWorker.class, 15, TimeUnit.MINUTES)
.setConstraints(Constraints.NONE)
.build();
WorkManager.getInstance().enqueue(work);
ClassExtendingWorker:
public Result doWork() {
/*--- SHOWING NOTIFICATION AS AN EXAMPLE TASK TO BE EXECUTED ---*/
NotificationCompat.Builder mBuilder = new NotificationCompat.Builder(getApplicationContext(), "")
.setSmallIcon(R.drawable.common_google_signin_btn_icon_light)
.setContentTitle("TestApp")
.setContentText("Code executed")
.setPriority(NotificationCompat.PRIORITY_DEFAULT);
NotificationManagerCompat notificationManager = NotificationManagerCompat.from(getApplicationContext());
notificationManager.notify(1234, mBuilder.build());
return Result.SUCCESS;
}
答案 0 :(得分:2)
将您的WorkManager版本更新为 1.0.0-alpha04 。 您可以查看发行说明here
此外,请参考PeriodicWorkRequest GitHub demo并根据DayIncrementViewModel.java
中的要求更新TimeUnit。它将根据您的需要工作。
WorkManager仍处于Alpha模式,因此一旦所有设备发布最终版本,它将完全适用于所有设备。
答案 1 :(得分:1)
如果以不超过15分钟的间隔使用PeriodicWorkRequest,则应返回Result.retry()
,而不是成功或失败。
答案 2 :(得分:0)
将伸缩间隔和伸缩单位添加到构建器构造函数。就我而言,它开始起作用。
PeriodicWorkRequest work = new PeriodicWorkRequest.Builder(ClassExtendingWorker.class, 15, TimeUnit.MINUTES, 5, TimeUnit.MINUTES)
答案 3 :(得分:0)
根据文档:
/**
* The minimum interval duration for {@link PeriodicWorkRequest} (in milliseconds).
*/
public static final long MIN_PERIODIC_INTERVAL_MILLIS = 15 * 60 * 1000L; // 15 minutes.
/**
* The minimum flex duration for {@link PeriodicWorkRequest} (in milliseconds).
*/
public static final long MIN_PERIODIC_FLEX_MILLIS = 5 * 60 * 1000L; // 5 minutes.
如果您将这两个值设置为小于指定的最小值,则必须等待大约20分钟才能看到日志/输出