我们在《利用LifeCycle解耦组件》这篇文章中介绍了LifeCycle,以及如何利用LifeCycle监听页面(Activity/Fragment)的生命周期,以达到解耦组件的目地。
我们知道,拥有生命周期概念的组件,除了Activity和Fragment,还有一个非常重要的组件是Service。为了方便我们对Service生命周期的监听,Android提供了一个名为LifecycleService的类,让该类继承自Service,并实现LifecycleOwner接口。

与Activity/Fragment类似,它也提供了一个名为getLifecycle()方法供我们使用。

接下去,让我们一起来看看,LifecycleService该如何使用。
由于LifecycleService存在于扩展包中,所以,首先我们需要在app的build.gradle文件中添加依赖:
implementation "android.arch.lifecycle:extensions:1.1.1"
添加成功后,便可以使用LifecycleService类。我们创建一个名为MyService的类,继承自LifecycleService。LifecycleService是Service的直接子类,使用起来与普通Service没有差别。
public class MyService extends LifecycleService
{
private MyServiceObserver myServiceObserver;
public MyService()
{
myServiceObserver = new MyServiceObserver();
getLifecycle().addObserver(myServiceObserver);//添加观察者
}
}
接下来是MyServiceObserver类,该类需要实现LifecycleObserver接口。如果你希望你的某个方法能够在Service生命周期发生变化时得到同步调用,那么,可以使用@OnLifecycleEvent标签,对其进行标记。
public class MyServiceObserver implements LifecycleObserver
{
private String TAG = this.getClass().getName();
//我希望该方法在Service的onCreate()方法调用时,得到调用
@OnLifecycleEvent(Lifecycle.Event.ON_CREATE)
private void startGetLocation()
{
Log.d(TAG, "startGetLocation()");
}
//我希望该方法在Service的onDestroy()方法调用时,得到调用
@OnLifecycleEvent(Lifecycle.Event.ON_DESTROY)
private void stopGetLocation()
{
Log.d(TAG, "stopGetLocation()");
}
}
最后,我们在页面中利用两个Button,控制Service的启动和停止,以测试我们的代码。
findViewById(R.id.btnStartService).setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
Intent intent = new Intent(MainActivity.this, MyService.class);
startService(intent);//启动
}
});
findViewById(R.id.btnStopService).setOnClickListener(new View.OnClickListener()
{
@Override
public void onClick(View v)
{
Intent intent = new Intent(MainActivity.this, MyService.class);
stopService(intent);//停止
}
});
在Logcat中可以看到,MyServiceObserver中带有@OnLifecycleEvent标签的方法,伴随着Service生命周期的变化,自动被调用了。这样,我们便完成了对Service生命周期的监听。
com.michael.lifecycleservicedemo.MyServiceObserver: startGetLocation()
com.michael.lifecycleservicedemo.MyServiceObserver: stopGetLocation()
项目地址:michaelye/LifecycleServiceDemo?