官方文档地址:https://developer.android.google.cn/topic/libraries/architecture/lifecycle#java
以前我们的生命周期都是在Activity/Fragment里面去管理,代码量很多。这种模式会导致代码条理性很差而且会扩散错误。通过使用生命周期感知型组件,可以将依赖组件的代码从生命周期方法移入组件本身中。
首先我们引入Lifecycle库
implementation "androidx.lifecycle:lifecycle-runtime-ktx:$lifecycle_version"
- 生命周期感知型组件的最佳做法做了介绍
https://developer.android.google.cn/topic/libraries/architecture/lifecycle#lc-bp - 使界面控制器(Activity 和 Fragment)尽可能保持精简。它们不应试图获取自己的数据,而应使用
ViewModel
执行此操作,并观察LiveData
对象以将更改体现到视图中。 - 设法编写数据驱动型界面,对于此类界面,界面控制器的责任是随着数据更改而更新视图,或者将用户操作通知给
ViewModel
。 - 将数据逻辑放在
ViewModel
类中。ViewModel
应充当界面控制器与应用其余部分之间的连接器。不过要注意,ViewModel
不负责获取数据(例如,从网络获取)。ViewModel
应调用相应的组件来获取数据,然后将结果提供给界面控制器。 - 使用 Data Binding 在视图与界面控制器之间维持干净的接口。这样一来,您可以使视图更具声明性,并尽量减少需要在 Activity 和 Fragment 中编写的更新代码。如果您更愿意使用 Java 编程语言执行此操作,请使用诸如 Butter Knife 之类的库,以避免样板代码并实现更好的抽象化。
- 如果界面很复杂,不妨考虑创建 presenter 类来处理界面的修改。这可能是一项艰巨的任务,但这样做可使界面组件更易于测试。
- 避免在
ViewModel
中引用View
或Activity
上下文。 如果ViewModel
存在的时间比 Activity 更长(在配置更改的情况下),Activity 将泄露并且不会由垃圾回收器妥善处置。 - 使用 Kotlin 协程管理长时间运行的任务和其他可以异步运行的操作。
我们写一个倒计时的定时器,在突然退出页面的时候需要销毁这个定时器,让这个定时器跟随响应生命周期的当前状态
我们要通过调用 Lifecycle
类的 addObserver()
方法并传递观察者的实例来添加观察者。首先我们编写一个观察者,通过注解的方式在特定的生命周期实现具体业务
class CounterListener : LifecycleObserver {
var counter: CountDownTimer = object : CountDownTimer(5000 * 1000L, 1000L) {
/**
* Callback fired when the time is up.
*/
override fun onFinish() {
Log.i("CounterListener:", "onFinish")
}
/**
* Callback fired on regular interval.
* @param millisUntilFinished The amount of time until finished.
*/
override fun onTick(millisUntilFinished: Long) {
Log.i("CounterListener:", "onTick:${millisUntilFinished}")
}
}
@OnLifecycleEvent(Lifecycle.Event.ON_RESUME)
fun startCount() {
counter.start()
Log.i("CounterListener:", "start")
}
@OnLifecycleEvent(Lifecycle.Event.ON_DESTROY)
fun stopCount() {
counter.cancel()
Log.i("CounterListener:", "cancel")
}
}
与此同时,所有者可以提供生命周期,而观察者可以注册以观察生命周期。生命周期由Activity/Fragement提供lifecycle
override fun onActivityCreated(savedInstanceState: Bundle?) {
super.onActivityCreated(savedInstanceState)
lifecycle.addObserver(CounterListener())
}
而使用这个的条件是Support Library 26.1.0 及更高版本,它们的 Fragment 和 Activity 已实现 LifecycleOwner
接口
另外实现自定义的可以查看官方给出的样例https://developer.android.google.cn/topic/libraries/architecture/lifecycle#implementing-lco