从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