我们有两种方式(start与bind)启动一个Service,每一种方式启动的Service生命周期是不一样的,这篇贴子主要写的是 start service。
它的生命周期中只有三个阶段:onCreate, onStartCommand(取代原来的onStart方法), onDestroy。如下图:
需要注意的有:
① 如果是 调用者 直接退出而没有调用 stopService 的话,那么被启动的 Service 会一直在后台运行,直至其stopService 方法被调用,或者它自己调用stopSelf 方法。
② 在服务未被创建时,系统会先调用服务的onCreate()方法,接着调用onStartCommand()方法。如果调用startService()方法前服务已经被创建,那么会直接调用onStartCommand()方法。也就是说,多次调用startService()方法并不会导致多次创建服务。另外,不管被 start 多少次,只需一次 stop 便可将相应的service关闭。
③ 具体的操作应该放在 onStartCommand() 里面
以下通过截图来看:
上图的中的四个按钮均是针对于同一个Service进行的操作,此时去 application ,可以查看到 "Running Service" 的列表如下:
这个,我们去点击上面的按钮(分别点击startservice 1 和 2 各两次),结果如下:
从图中,我们可以看出, onCreate() 方法只在第一次创建服务的时候被调用了。
现在,通过“返回键”来退回至主界面,然后再去 application 的 running service中去查看,可得下面的截图:
从此图中,我们可以看出,虽然Activity被finish掉了,但是由它启动的service仍然在后台运行着。
此时,重新打开该应用,然后直接点击 stop service 1 和 2 按钮各两次(不需再新点击 start service按钮),可以如下截图:
从此图中我们可以看出,只有第一次停止服务的时候,才会调用 onDestroy() 方法。
此时,再去 application 的 running service中去查看,可得下面的截图,发现服务确实已经被停止了:
下面附上部分源码(具体地请参见附件):
// 四个按钮的响应事件 private OnClickListener btnListener = new OnClickListener() { @Override public void onClick(View v) { switch (v.getId()) { case R.id.startSer1: updateLog("Start Service 1 pressed"); // 启动服务(如果想传递数据,也可以将其封装进该intent) startService(intent); break; case R.id.startSer2: updateLog("Start Service 2 pressed"); startService(intent); break; case R.id.stopSer1: updateLog("Stop Service 1 pressed"); // 停止服务 stopService(intent); break; case R.id.stopSer2: updateLog("Stop Service 2 pressed"); stopService(intent); break; default: break; } } };
// service 的实现 public class MyService extends Service { private static final String TAG = "MyService"; @Override public void onCreate() { super.onCreate(); MyServiceActivity.updateLog(TAG + " ----> onCreate()"); } @Override public int onStartCommand(Intent intent, int flags, int startId) { MyServiceActivity.updateLog(TAG + " ----> onStartCommand()"); return START_STICKY; } @Override public IBinder onBind(Intent intent) { MyServiceActivity.updateLog(TAG + " ----> onBind()"); return null; } @Override public void onDestroy() { super.onDestroy(); MyServiceActivity.updateLog(TAG + " ----> onDestroy()"); } }