###在startService启动一个Service 时会执行onStartCommand(Intent intent, int flags, int startId)
####参数:
intent:是startService时传过来的 如:startService(new Intent(this,TestService.class));
flags:是系统传入 有如下三种值:
1,通过startService启动时,flags为0;
2,onStartCommand返回为START_STICKY_COMPATIBILITY或者START_STICKY并且服务异常杀死后由系统启动;flags为START_FLAG_REDELIVERY=1:
3,onStartCommand返回为START_REDELIVER_INTENT并且服务异常杀死后由系统启动;
flags为START_FLAG_REDELIVERY=2:
startId:大概是onStartCommand的启动次数,第一次通过startService启动为是1,不断startService启动依次累加,一般配合stopSelf(startId)使用可以看IntentService中使用
####返回值
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后一定能重启。
以上实在5.1上测试的