Android中Service类onStartCommand的返回值

本文详细解析了Android Service类的onStartCommand方法的四种返回类型及其工作原理,包括START_STICKY、START_NOT_STICKY、START_REDELIVER_INTENT和START_STICKY_COMPATIBILITY,通过流程图和代码片段帮助开发者深入理解服务生命周期管理和重启策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Android中Service类的onStartCommand有4种返回值解释如下:

1.START_STICKY:如果service进程被kill掉,保留service的状态为开始状态,但不保留递送的intent对象。随后系统会尝试重新创建service,由于服务状态为开始状态,所以创建服务后一定会调用onStartCommand(Intent,int,int)方法。如果在此期间没有任何启动命令被传递到service,那么参数Intent将为null;
过程如下:
onCreate
onStartCommand
onCreate
onStartCommand  startId + 1 ,intent = null

2.START_NOT_STICKY:“非粘性的”。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统不会自动重启该服务;
过程如下:
onCreate
onStartCommand
没了
3.START_REDELIVER_INTENT:重传Intent。使用这个返回值时,如果在执行完onStartCommand后,服务被异常kill掉,系统会自动重启该服务,并将Intent的值传入;
过程如下:
onCreate
onStartCommand
onCreate
onStartCommand startId不变,inutent != null

4.START_STICKY_COMPATIBILITY:START_STICKY类似,不过是调用oncreate 方法,没有调用 onStartCommand。
过程如下:
onCreate
onStartCommand
onCreate

我们再来看一下Service 源码里面,onStartCommand 方法的原型
public int onStartCommand(Intent intent, int flags, int startId) {
        onStart(intent, startId);
        return mStartCompatibility ? START_STICKY_COMPATIBILITY : START_STICKY;
 }
那么mStartCompatibility值是什么呢?
mStartCompatibility = 

            getApplicationInfo().targetSdkVersion < Build.VERSION_CODES.ECLAIR;

可以看出,只要我们的应用程序 targetSdkVersion 小于 2.0
那么就返回 START_STICKY_COMPATIBILITY,否则返回 START_STICKY




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值