Android中Service类onStartCommand的返回值问题(转)

 

	@Override
	public int onStartCommand(Intent intent, int flags, int startId) {
		 System.out.println("---------->>onStartCommand2");
		return super.onStartCommand(intent, flags, startId);
	}
 

Android中Service类onStartCommand的返回值问题

 
Android开发的过程中,每次调用startService(Intent)的时候,都会调用该Service对象的onStartCommand(Intent,int,int)方法,然后在onStartCommand方法中做一些处理。然后我们注意到这个函数有一个int的返回值,这篇文章就是简单地讲讲int返回值的作用。
从Android官方文档中,我们知道onStartCommand有4种返回值:

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后一定能重启。
当程序在运行时被杀死,当重新启动这个服务的时候,最有的一个Intent将会被传递过的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Android Service 是一种后台运行的组件,它可以在不与用户交互的情况下执行长时间运行的任务。Service 有两种类型:Started Service 和 Bound Service。 对于 Started Service,它是通过 startService() 方法启动的,而 onStartCommand() 方法是它的生命周期方法之一,用于响应 startService() 方法的调用。 onStartCommand() 方法在 Service 第一次启动时调用,并在每次调用 startService() 方法时都会被调用。它的返回表示 Service 的启动类型,有以下三个选项: 1. START_NOT_STICKY:Service 被杀死后不会自动重启。 2. START_STICKY:Service 被杀死后会自动重启,并尝试重新创建之前未完成的任务。 3. START_REDELIVER_INTENT:Service 被杀死后会自动重启,并尝试重新创建之前未完成的任务,同时还会重新传递 Intent。 而 onCreate() 方法则是 Service 的生命周期方法之一,用于初始化 Service。它在 Service 第一次被创建时调用,而 onStartCommand() 方法则在 onCreate() 方法之后调用。 总结一下,Service 的生命周期如下: 1. onCreate():用于初始化 Service。 2. onStartCommand():用于响应 startService() 方法的调用,并决定 Service 的启动类型。 3. onDestroy():用于销毁 Service。 对于 Bound Service,它是通过 bindService() 方法启动的,与 Started Service 不同,它需要与客户端进行绑定,因此需要 onBind() 方法来返回 IBinder 接口,以便客户端与 Service 进行交互。Bound Service 的生命周期方法如下: 1. onCreate():用于初始化 Service。 2. onBind():用于返回 IBinder 接口。 3. onUnbind():用于解绑 Service。 4. onDestroy():用于销毁 Service

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值