gpt4 book ai didi

android - 应用程序关闭后,WorkManager 停止调度周期性 Worker

转载 作者:行者123 更新时间:2023-12-04 01:34:11 25 4
gpt4 key购买 nike

也许这是关于 WorkManager 的另一个问题,但我真的找不到解决方案...

正如标题所示,我正在尝试每 15 分钟运行一次周期性工作。实际上,在工作人员中,我每分钟都在轮询一些数据。每次轮询后,几乎每隔 1 秒我检查工作人员是否正在停止,如果停止则返回,否则继续等待直到达到 1 分钟并再次轮询数据。

根据文档,这应该有效,而且确实如此,直到我从最近的应用程序屏幕中终止该应用程序。

代码如下:

package com.qsea.app.cordova;

import android.content.Context;

import android.os.SystemClock;

import android.util.Log;

import androidx.work.Worker;
import androidx.work.WorkerParameters;

public class ServerListenerWorker extends Worker {

public static final String TAG = "ServerListenerWorker";

public ServerListenerWorker(
Context appContext,
WorkerParameters workerParams
) {
super(appContext, workerParams);
}

@Override
public Result doWork() {

Log.d(TAG, "Doing work");

final long startTime = SystemClock.elapsedRealtime();
final int maxDelta = 840000; // 14 minutes

while (true) {
// I did this to stop this worker until 15 minutes
// and then let the next worker run
if (SystemClock.elapsedRealtime() - startTime >= maxDelta) {
break;
}

// Here I'm polling data, if the polling results in a failure
// I return Result.retry()

// It avoid waiting if it remains only 1 minute until the max time
if (SystemClock.elapsedRealtime() - startTime >= (maxDelta - 60000)) {
break;
}
for (int i = 0; i < 60; i++) {
SystemClock.sleep(950);
// Here it checks if it is stopped
if (isStopped()) {
Log.d(TAG, "Detected stop"); // this is actually never reached
break;
}
}
}
return Result.success();
}
}

然后我按照以下步骤开始工作

Constraints constraints = new Constraints.Builder().setRequiredNetworkType(NetworkType.CONNECTED).build();
PeriodicWorkRequest periodicWorkRequest = new PeriodicWorkRequest.Builder(ServerListenerWorker.class, 15, TimeUnit.MINUTES)
.addTag(serverListenerWorkerUID)
.setConstraints(constraints)
.build();
WorkManager.getInstance(cordova.getActivity()).enqueueUniquePeriodicWork(serverListenerWorkerUID, ExistingPeriodicWorkPolicy.KEEP, periodicWorkRequest);

我通过查看我的服务器日志来检查工作人员是否正常工作(如果我收到请求,它工作正常)并且它似乎工作正常,直到我关闭应用程序。然后它停止运行实际的工作人员并且在我重新打开应用程序之前不再运行工作人员,其中工作似乎已排队并在应用程序打开后立即恢复。

我在初始化时做错了什么吗?我也有<service android:name=".ServerListenerWorker" android:permission="android.permission.BIND_JOB_SERVICE" />在我的 AndroidManifest.xml 中

这是预期的行为吗?

我读到中文 ROM 对后台服务有额外的限制,我有一个 HUAWEI,这似乎是最糟糕的。那么它可能是设备吗?如果是这样,Facebook、WhatsApp、Instagram 和其他公司如何管理它以在这些设备上正常工作?

最佳答案

让我们把它分成两个不同的问题。

  1. 您在 worker 中所做的工作耗电量大,如果您使用前台服务来通知用户您的应用程序正在后台持续运行会更好。您还可以将 WorkManager 与新引入的对长时间运行的工作人员的支持结合使用(在后台使用前台服务)。 More on this in the documentation .

  2. 如果特定 OEM 有问题,请 open an issue on the Android issuetracker因为这可能违反 CDD。 Google 可以联系 OEM 并请求他们修复 ROM。这需要时间,与此同时,您可以查看 don't kill my app 等网站。了解特定设备的限制是什么,并使用像 autostarter 这样的库帮助用户导航到正确的设置。

顺便说一句,您不需要在 AndroidManifest.xml 文件中列出您的工作人员

关于android - 应用程序关闭后,WorkManager 停止调度周期性 Worker,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60125918/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com