从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后一定能重启。
那么默认的返回值是什么呢?
我们进入http://androidxref.com/查看安卓源码,
Android 7.0源码中的/frameworks/base/core/java/android/app/Service.java
我们可以发现,Android无论哪个版本的Service.java中默认返回值都是START_STICKY
public @StartResult int onStartCommand(Intent intent, @StartArgFlags int flags, int startId) {
onStart(intent, startId);
return mStartCompatibility ? START_STICKY_COMPATIBILITY : START_STICKY;
}
从上述代码中,我们可以看到,默认的就是START_STICKY. 也就是在意外被杀死的情况下,会自动重启.
不信我们来做个实验,看以下代码, 是我写的Service,在应用启动后我会ps并kill掉我们的进程,可以预料的是我们的onStartCommand再次会被打印出来.
/**
* Created by xiamin on 1/17/17.
*/
public class MyService extends Service {
@Override
public IBinder onBind(Intent intent) {
return myAidlInterface;
}
@Override
public void onCreate() {
Log.d("xiamin","onCreate");
super.onCreate();
}
@Override
public int onStartCommand(Intent intent, int flags, int startId) {
Log.d("xiamin","onStartCommand");
return super.onStartCommand(intent,flags,startId);
}
@Override
public void onDestroy() {
super.onDestroy();
}
}
调用方: startService(new Intent(this, MyService.class));
我们先运行程序
Log如下:
01-22 10:48:30.340 16912-16912/com.xiamin.android D/xiamin: onCreate
01-22 10:48:30.340 16912-16912/com.xiamin.android D/xiamin: onStartCommand
然后kill我们的程序
xiamin@xiamin:~$ adb shell ps | grep xiamin
u0_a42 16912 169 891676 20472 ffffffff 40143754 S com.xiamin.android
xiamin@xiamin:~$ adb shell kill -9 16912
xiamin@xiamin:~$
01-22 10:48:30.340 16912-16912/com.xiamin.android D/xiamin: onCreate
01-22 10:48:30.340 16912-16912/com.xiamin.android D/xiamin: onStartCommand
01-22 10:49:07.640 16912-16916/com.xiamin.android D/dalvikvm: Debugger has detached; object registry had 1 entries
01-22 10:49:42.160 499-829/system_process I/ActivityManager: Process com.xiamin.android (pid 16912) has died.
01-22 10:49:43.210 499-515/system_process I/ActivityManager: Start proc com.xiamin.android for service com.jerey.learning/.MyService: pid=18000 uid=10042 gids={50042}
01-22 10:49:43.250 18000-18000/com.xiamin.android I/InstantRun: Instant Run Runtime started. Android package is com.jerey.learning, real application class is null.
01-22 10:49:43.250 18000-18000/com.xiamin.android W/InstantRun: No instant run dex files added to classpath
01-22 10:49:43.250 18000-18000/com.xiamin.android D/xiamin: onCreate
01-22 10:49:43.260 18000-18000/com.xiamin.android D/xiamin: onStartCommand
可以见到,我们的Service再次被起来了.再次打印了onStartCommand
作者:Anderson大码渣,欢迎关注我的简书: Anderson大码渣