IllegalArgumentException:没有此类服务ComponentInfo {JobIntentService}

时间:2018-10-08 08:06:38

标签: android android-8.0-oreo illegalargumentexception jobintentservice

关于这个问题的答案并没有帮助我,我已经声明了所有权限,并且已经在我的代码中接受了答案。

AppInfoJobService(CustomJobIntentService)在Android OS 8+设备上引发以下错误,并且这种情况很少发生,无法重现。 我们将工作加入BaseActivity的onCreate中。我们主要有一个活动和片段。

Fatal Exception: java.lang.IllegalArgumentException: No such service ComponentInfo{<app package>AppInfoJobService}
   at android.os.Parcel.readException(Parcel.java:2009)
   at android.os.Parcel.readException(Parcel.java:1951)
   at android.app.job.IJobScheduler$Stub$Proxy.enqueue(IJobScheduler.java:211)
   at android.app.JobSchedulerImpl.enqueue(JobSchedulerImpl.java:53)
   at android.support.v4.app.JobIntentService$JobWorkEnqueuer.enqueueWork(JobIntentService.java:342)
   at android.support.v4.app.JobIntentService.enqueueWork(JobIntentService.java:522)
   at android.support.v4.app.JobIntentService.enqueueWork(JobIntentService.java:500)
   at <application package>AppInfoJobService.startWork(AppInfoJobService.java:254)
   at <application package>MyApplication.onStartStopChanged(MusicApplication.java:694)
   at <application package>AppStateMonitor.notifyStartStop(AppStateMonitor.java:150)
   at <application package>AppStateMonitor.access$000(AppStateMonitor.java:14)
   at <application package>AppStateMonitor$CreateDestroyRunnable.run(AppStateMonitor.java:71)
   at android.os.Handler.handleCallback(Handler.java:790)
   at android.os.Handler.dispatchMessage(Handler.java:99)
   at android.os.Looper.loop(Looper.java:164)
   at android.app.ActivityThread.main(ActivityThread.java:6545)
   at java.lang.reflect.Method.invoke(Method.java)
   at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:438)
   at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:857) 

4 个答案:

答案 0 :(得分:5)

注意:,因为我没有足够的声誉来发表评论并希望为作者提供帮助,所以开始一个单独的话题。

这实际上是具有Android Oreo的LAVA设备的问题,并且在其他设备上也可以正常工作。

我在LAVA Z60s和LAVA Z61上也观察到了这一点。

从crashlytics中添加相关信息 enter image description here

答案 1 :(得分:1)

切换到新的Android WorkManager

后,问题终于解决了

答案 2 :(得分:-1)

我的情况是我没有在AndroidManifest.xml中创建服务,因此没有找到该服务。 为此,请在其上添加以下内容:

    ...
    /activity>
    <service
        android:name=".YOUR_FOLDER.YOUR_SERVICE_FILENAME"
        android:permission="android.permission.BIND_JOB_SERVICE"
        android:exported="false" />
    <receiver
        android:name=".YOUR_FOLDER.YOUR_RECEIVER_FILENAME"></receiver>

</application> 

答案 3 :(得分:-2)

当应用程序处于后台或应用程序被杀死并尝试重新启动服务时,您无法使用startService方法启动服务或intentService。

据我所知,情况是(正如您所说的那样,很少发生)应用程序在某种程度上试图在应用程序不在内存中时重新启动应用程序。