Android WorkManager - 应用程序终止后工作不正常
Android WorkManager - not working well after application kill
我创建了简单的 workManager,我希望它在后台每 1 秒进行 50 次 for 循环,因此它将每 1 秒迭代一次循环并显示日志。首先让我介绍一下我的代码。
这是 WorkManager class。
public class WorkerClass extends Worker {
private static String TAG = "work_tag";
public WorkerClass(@NonNull Context context, @NonNull WorkerParameters workerParams) {
super(context, workerParams);
}
@NonNull
@Override
public Result doWork() {
try {
loop();
} catch (InterruptedException e) {
e.printStackTrace();
}
return Result.success();
}
private void loop() throws InterruptedException {
for (int i = 0; i < 50; i++) {
Thread.sleep(1000);
Log.d(TAG, "Working: " + i);
}
}
}
这是我的 MainActivity。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
OneTimeWorkRequest oneTimeWorkRequest = new OneTimeWorkRequest.Builder(WorkerClass.class).build();
WorkManager.getInstance().enqueue(oneTimeWorkRequest);
}
}
如有不妥请告知。所以当我启动应用程序时,它会像这样每 1 秒显示一次日志。
D/work_tag: Working: 1
D/work_tag: Working: 2
D/work_tag: Working: 3
D/work_tag: Working: 4
D/work_tag: Working: 5
好的,是吗?因此,当我终止应用程序 (onDestroy) 时,30-35 秒后循环再次在后台开始。之后,当我打开应用程序时,循环再次开始,而没有完成上一个循环。
例如在后台循环中迭代 50 次 25 次,如果我打开应用程序,日志将是这样的。
D/work_tag: Working: 25
D/work_tag: Working: 0
D/work_tag: Working: 26
D/work_tag: Working: 1
D/work_tag: Working: 27
D/work_tag: Working: 2
D/work_tag: Working: 28
D/work_tag: Working: 3
D/work_tag: Working: 29
D/work_tag: Working: 4
看到了吗?打开 app 2 循环后开始异步迭代。
所以第一个问题是如何避免这种情况发生(2 个异步循环),第二个问题是为什么在销毁应用程序后我必须等待 30-35 秒才能在后台运行循环?
我正在 android 6.0
中对此进行测试
在android4.4后台任务根本没有调度
此时您是 运行 worker 的两个不同副本 - 每次您的 Activity 启动时,您都在排队一个新的 WorkRequest。如果您只想使用一份副本,请使用唯一的工作请求:https://developer.android.com/reference/androidx/work/WorkManager#enqueueUniqueWork(java.lang.String,%20androidx.work.ExistingWorkPolicy,%20androidx.work.OneTimeWorkRequest)
我创建了简单的 workManager,我希望它在后台每 1 秒进行 50 次 for 循环,因此它将每 1 秒迭代一次循环并显示日志。首先让我介绍一下我的代码。
这是 WorkManager class。
public class WorkerClass extends Worker {
private static String TAG = "work_tag";
public WorkerClass(@NonNull Context context, @NonNull WorkerParameters workerParams) {
super(context, workerParams);
}
@NonNull
@Override
public Result doWork() {
try {
loop();
} catch (InterruptedException e) {
e.printStackTrace();
}
return Result.success();
}
private void loop() throws InterruptedException {
for (int i = 0; i < 50; i++) {
Thread.sleep(1000);
Log.d(TAG, "Working: " + i);
}
}
}
这是我的 MainActivity。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
OneTimeWorkRequest oneTimeWorkRequest = new OneTimeWorkRequest.Builder(WorkerClass.class).build();
WorkManager.getInstance().enqueue(oneTimeWorkRequest);
}
}
如有不妥请告知。所以当我启动应用程序时,它会像这样每 1 秒显示一次日志。
D/work_tag: Working: 1
D/work_tag: Working: 2
D/work_tag: Working: 3
D/work_tag: Working: 4
D/work_tag: Working: 5
好的,是吗?因此,当我终止应用程序 (onDestroy) 时,30-35 秒后循环再次在后台开始。之后,当我打开应用程序时,循环再次开始,而没有完成上一个循环。
例如在后台循环中迭代 50 次 25 次,如果我打开应用程序,日志将是这样的。
D/work_tag: Working: 25
D/work_tag: Working: 0
D/work_tag: Working: 26
D/work_tag: Working: 1
D/work_tag: Working: 27
D/work_tag: Working: 2
D/work_tag: Working: 28
D/work_tag: Working: 3
D/work_tag: Working: 29
D/work_tag: Working: 4
看到了吗?打开 app 2 循环后开始异步迭代。 所以第一个问题是如何避免这种情况发生(2 个异步循环),第二个问题是为什么在销毁应用程序后我必须等待 30-35 秒才能在后台运行循环?
我正在 android 6.0
中对此进行测试在android4.4后台任务根本没有调度
此时您是 运行 worker 的两个不同副本 - 每次您的 Activity 启动时,您都在排队一个新的 WorkRequest。如果您只想使用一份副本,请使用唯一的工作请求:https://developer.android.com/reference/androidx/work/WorkManager#enqueueUniqueWork(java.lang.String,%20androidx.work.ExistingWorkPolicy,%20androidx.work.OneTimeWorkRequest)