默认情况下Service被意外杀死会自动重启么

从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

1
2
3
4
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再次会被打印出来.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
/**
* 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如下:

1
2
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:~$

1
2
3
4
5
6
7
8
9
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