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

Posted by 夏敏的博客 on January 10, 2017

从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大码渣