安卓8.0手机线上报错:
java.lang.IllegalStateException:Fatal Exception thrown on Scheduler. |
|
2 io.reactivex.android.schedulers.HandlerScheduler$ScheduledRunnable.void run()(HandlerScheduler.java:111) |
|
3 ...... |
|
4 java.lang.IllegalStateException:Not allowed to start service Intent { cmp=com.xianglin.app/.biz.gold.service.StepService }: app is in background uid UidRecord{be88278 u0a36 SVC bg:+1m4s717ms idle procs:4 seq(0,0,0)} |
|
5 android.app.ContextImpl.startServiceCommon(ContextImpl.java:1701) |
|
6 android.app.ContextImpl.startService(ContextImpl.java:1657) |
|
7 android.content.ContextWrapper.startService(ContextWrapper.java:644) |
|
8 com.xianglin.app.utils.AppUtils.void setupService(android.content.Context)(AppUtils.java:479) |
|
9 com.xianglin.app.utils.net.NetStateChangeReceiver$1.void onSuccess(com.xianglin.appserv.common.service.facade.model.vo.LoginVo)(NetStateChangeReceiver.java:195) |
|
10 com.xianglin.app.utils.net.NetStateChangeReceiver$1.void onSuccess(java.lang.Object)(NetStateChangeReceiver.java:191) |
错误原因:
Android 8.0 不再允许后台service直接通过startService方式去启动, 具体行为变更如下:
如果针对 Android 8.0 的应用尝试在不允许其创建后台服务的情况下使用 startService() 函数,则该函数将引发一个 IllegalStateException。 新的 Context.startForegroundService() 函数将启动一个前台服务。现在,即使应用在后台运行, 系统也允许其调用 Context.startForegroundService()。不过,应用必须在创建服务后的五秒内调用该服务的 startForeground() 函数。
解决方法:
1. 修改启动方式
-
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
-
context.startForegroundService(intent);
-
} else {
-
context.startService(intent);
-
}
2. 并且在service里再调用startForeground方法,不然就会出现ANR
context.startForeground(SERVICE_ID, builder.getNotification());
-
判断下版本,startForeground(1, new Notification())放在oncrea