赞
踩
百度一下这个问题 答案一大堆
都讲到了 onStartCommand 这个方法的返回值,
START_STICKY:如果service进程被kill掉,保留service的状态为开始状态,但不保留递送的intent对象。随后系统会尝试重新创建service,由于服务状态为开始状态,所以创建服务后一定会调用onStartCommand(Intent,int,int)方法。如果在此期间没有任何启动命令被传递到service,那么参数Intent将为null。
START_NOT_STICKY:“非粘性的”。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统不会自动重启该服务。
START_REDELIVER_INTENT:重传Intent。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统会自动重启该服务,并将Intent的值传入。
START_STICKY_COMPATIBILITY:START_STICKY的兼容版本,但不保证服务被kill后一定能重启。
可以根据需求设置为任意一种
问题来了 我设置之后,程序异常并没有重新调起服务,进程也没有了.
但是直接用adb kill 掉我自己的进程 service的确会被重新onCreate,但是异常报错却不行
但我需要的异常报错想拉起啊 !!!!!!
最终被我找到了application属性: android:persistent=true (基于我的app是系统app的基础这个属性才生效)
可将app设为常驻型app
参考
https://blog.csdn.net/windskier/article/details/6560925
源代码分析参考:
https://blog.csdn.net/yaobao888/article/details/77824950
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。