以下内容都是针对start方式启动的service,而非bind启动的srevice。因为bind启动的服务生命周期始于Activity绑定在一起的,会随Activity的销毁而停止。但start方式启动的service独立的,即使应用销毁它也可以继续运行,故Android系统会随版本升高逐渐限制后台应用start开启的服务。
在这里插入图片描述

1、Android 8.0 异常报错

在Android 8.0 系统中,处于后台的应用想要开启前台服务,必须满足两点:

  1. 在Activity中调用startForegroundService()方法
  2. 所调起的Service必须执行startForeground(int id, Notification notification)方法,发送一个通知展示给用户看,告诉用户自己在站着资源。若不发通知则会ARN + Crash套餐。

【异常1】IllegalStateException: Not allowed to start service Intent

【产生原因】后台应用开启服务时,使用的startService()方法,而非startForegroundService()方法
【解决方案】后台应用开启服务时使用startForegroundService()方法

【异常2】RemoteServiceException: Context.startForegroundService() did not then call Service.startForeground()

【产生原因】后台应用调用了startForegroundService()方法,但是调起的Service没有调用startForeground(int id, Notification notification)发送前台通知
【解决方案】调起的服务要调用startForeground(int id, Notification notification)方法发送前台通知

注意:startForeground(int id, Notification notification)中的id不可为0,否则也会发生Crash

2、Android 12.0 异常报错

【异常】ForegroundServiceStartNotAllowedException

【产生原因】Android 12.0及以上,禁止后台应用开启前台服务(特殊情况除外)
【解决方案】使用WorkManager代替。官方说明

标题Android 12.0 中允许后台应用开启前台服务的特殊情况

在这里插入图片描述

以上是根据官方文档总结而得,但实际编码中发现,Android 8.0以上,后台应用开启前台服务时,只要startForeground(),startForeground()就不会ANR+Crash

参考文档
android8.0后台服务

JobScheduler
JobScheduler

ANR

android12 后台服务
android12后台服务-官方文档

Logo

为开发者提供学习成长、分享交流、生态实践、资源工具等服务,帮助开发者快速成长。

更多推荐