您的位置:首页 > Web前端

LiveData,ViewModel,Lifecycle原理解析以及使用

2019-02-18 14:53 495 查看

一. 使用

Lifecycle如果用Activity/Fragment的话,可以不必理会,直接用support包版本26.1.0以上的AppCompactActivity/FragmentActivity(继承自SupportActivity)或者Fragment即可

一般由Activity在onCreate()的时候通过ViewProviders.of(this).get(xxxViewModel.class)创建,例如

[code]public class MyActivity extends FragmentActivity {

MyActivity mViewModel;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my);

mViewModel = ViewModelProviders.of(this).get(MyActivityViewModel.class);
}
}

Activity直接调用ViewModel去做一些业务逻辑,并通过监听ViewModel中的LiveData变化来更新界面

[code]public class MyActivity extends FragmentActivity {

MyActivityViewModel mViewModel;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_my);

mViewModel = ViewModelProviders.of(this).get(MyActivityViewModel.class);

mViewModel.getProductShowLiveData().observe(this, product -> {
if (product.isConnected()) {
// 更新UI
mTextView.setText(getString(product.getNameId());
}
});
// 一些业务逻辑
mViewModel.doSomeBusiness();
}
}
[code]public class MyActivityViewModel extends BaseRxViewModel<MyActivityRepository> {

private MutableLiveData<ProductTypeShowData> mProductShowLiveData = new MutableLiveData<>();

public MyActivityViewModel(@NonNull Application application) {
super(application);
}

private void doSomeBusiness() {
// 一些业务逻辑
...
// 通知UI更新,并将UI需要的数据源setValue通知出去
mProductShowLiveData.setValue(XXXX);
}
}

二. 原理

ViewModel

ViewModel的功能在于能自动处理转屏,切换输入法等配置变更引起的Activity销毁,生命周期重走问题,使得重新生成的Activity拿到的依然是之前的ViewModel,也即该ViewModel的生命周期是从Activity start到finish,中间不管因为配置变更Activity销毁重启多少次,ViewModel都是不会重启的(所以不能在ViewModel里持有Activity的Context)

 


具体源码分析推荐可以阅读这篇文章,基本原理是在Activity上add一个setRetainInstance(true)的HolderFragment,由其保存对应Activity的ViewModelStore,在Activity重走生命周期后,在onCreate()中再次通过ViewModelProviders.of(this)找到对应的HolderFragment的ViewModelStore,并通过get(xxxViewModel.class)以class为key,找到存在ViewModelStore中的ViewModel。

 

(故在Fragment之间可以通过ViewModelProviders.of(getActivity()).get(xxxViewModel.class)来获取到相同的ViewModel,从而实现Fragment之间的ViewModel共享)

 

 

LiveData

LiveData的功能在于,在于setValue时(非UI线程使用postValue),会根据当前界面的生命周期(通过在界面上add一个无界面的ReportFragment,接收其生命周期回调来实现,很经典的做法,Glide比起其他的图片加载库有感知生命周期的功能也是这么做的),选择要不要回调到UI界面更新(在对应的Activity调用onStart()之前,onStop()之后,都是不会更新界面的),那么如果遇到这些情况,LiveData会选择在每一次对应界面的生命周期变化时,以及调用LiveData.observe()建立监听关系时再去尝试回调UI更新

 

LiveData分发消息过程以及触发时机

 

关于这块的源码,代码量其实也不多,LiveData相关的还是比较简单的,LifecycleRegistry分发生命周期稍微有一点点绕,但也还好,在使用过的基础上一天基本就能通读代码

源码解析链接里这位博主写的很好:

LiveData:

https://jekton.github.io/2018/07/14/android-arch-LiveData/

Lifecycle

https://jekton.github.io/2018/07/06/android-arch-lifecycle/

三. 总结

LiveData,ViewModel以及Lifecycle相关的api都已经被收录进了google推出的帮助开发者更快更专注地开发app的jetpack火箭背包里,现在最新的代码都在androidx库上更新

https://developer.android.com/topic/libraries/architecture/adding-components#lifecycle

 

 

+qq群:853967238。获取以上高清技术思维图,以及相关技术的免费视频学习资料。

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐