LiveData,ViewModel,Lifecycle原了解析以及使用
一. 使用
Lifecycle假如用Activity/Fragment的话,可以不必理睬,直接用support包版本26.1.0以上的AppCompactActivity/FragmentActivity(继承自SupportActivity)或者者Fragment就可
一般由Activity在onCreate()的时候通过ViewProviders.of(this).get(xxxViewModel.class)创立,例如
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变化来升级界面
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(); }}
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)
ViewModel生命周期
具体源码分析推荐可以阅读这篇文章,基本原理是在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共享)
ViewModelProviders.of(this).get(xxxViewModel.class)实际的内部结构
LiveData
LiveData的功能在于,在于setValue时(非UI线程使用postValue),会根据当前界面的生命周期(通过在界面上add一个无界面的ReportFragment,接收其生命周期回调来实现,很经典的做法,Glide比起其余的图片加载库有感知生命周期的功能也是这么做的),选择要不要回调到UI界面升级(在对应的Activity调用onStart()之前,onStop()之后,都是不会升级界面的),那么假如遇到这些情况,LiveData会选择在每一次对应界面的生命周期变化时,以及调用LiveData.observe()建立监听关系时再去尝试回调UI升级
LiveData分发消息过程以及触发时机
Lifecycle.State
关于这块的源码,代码量其实也不多,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
AndroidX库引入
1. 本站所有资源来源于用户上传和网络,如有侵权请邮件联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系管理员处理!
6. 本站资源售价只是摆设,本站源码仅提供给会员学习使用!
7. 如遇到加密压缩包,请使用360解压,如遇到无法解压的请联系管理员
开心源码网 » LiveData,ViewModel,Lifecycle原了解析以及使用