JobService 不会在 android 9 中重新安排

Lin*_*Nox 6 android job-scheduling kotlin jobservice android-9.0-pie

我正在尝试让我的应用程序在 Android 9 上运行。以下代码在 Android 8 之前都可以正常工作,但出于某种原因,JobService 不会在 android 9 上重新安排。它第一次被安排,但不会根据到设置周期。

class RetrieveJobService : JobService() {

override fun onStartJob(params: JobParameters): Boolean {
    doBackgroundWork(params)
    return true
}

private fun doBackgroundWork(params: JobParameters) {
    Thread {
        try {
            doRetrieveBackgroundStuff(this)
            jobFinished(params, false)
        } catch (e: Exception) {
            jobFinished(params, false)
        }
    }.start()
}

override fun onStopJob(params: JobParameters): Boolean {
    return false
}

}
Run Code Online (Sandbox Code Playgroud)

这里是我的 JobInfo.Builder

val builder = JobInfo.Builder(jobID, componentName)
                    .setPersisted(true)

if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.N) {
    builder.setPeriodic(millis, 15 * 60 * 1000) //15 min
} else {
    builder.setPeriodic(millis)
}
builder.setRequiredNetworkType(JobInfo.NETWORK_TYPE_UNMETERED)

val scheduler = context.getSystemService(JOB_SCHEDULER_SERVICE) as 
        JobScheduler
val resultCode = scheduler.schedule(builder.build())
Run Code Online (Sandbox Code Playgroud)

有任何想法吗?编辑:需要说明的是,此代码在 Android 8 及更低版本上运行良好,并且也适用于运行 Android 9 的 Android Studio 模拟器。据我所知,它不适用于任何运行 Android 9 的物理设备。

ank*_*ag2 8

如果你通过链接,你会发现:

不幸的是,一些设备将最近菜单中的应用程序杀死作为强制停止。Stock Android 不会这样做。当应用程序被强制停止时,它无法执行作业、接收警报或广播等。因此,不幸的是,我们无法解决它 - 问题在于操作系统,没有解决方法。

这是一个已知问题。很多厂商为了省电,强制关闭APP,取消了所有的周期任务、闹钟和广播接收器等。主要厂商有OnePlus(你可以选择toogle)、Redmi、Vivo、Oppo、Huwaei。

更新

这些设备中的每一个都有 AutoStartManagers/AutoLaunch/StartManager 类型的优化管理器。从而防止后台活动再次启动。您必须手动要求用户将您的应用程序列入白名单,以便应用程序可以自动启动其后台进程。按照这个这个链接,了解更多信息。

这个 stackoverflow answer中给出了添加到不同制造商的白名单的方法。即使添加到白名单后,您的应用程序也可能因为打盹模式而无法运行,为此您将不得不忽略电池优化

此外,如果您可能想知道,这些 AutoStart 管理器已经将 Gmail/Hangout/WhatsApp/Slack/LinkedIn 等应用程序列入白名单。因此,对其后台进程没有影响。您始终会及时收到更新和通知。

  • 只是想回应@LinusNox;一年后,我在 JobScheduler 上遇到了类似的问题。有人应该告诉谷歌,从开发者的角度来看,当我们被告知我们现在应该开始使用 JobScheduler 却发现它已经被锁定到几乎无法使用的地步时,这是非常令人沮丧的(除非你碰巧是谷歌或 Facebook 并且已预先列入白名单)。我理解想要延长电池寿命,但这太荒谬了。/咆哮 (2认同)