LiveData 的概述:
LiveData 是一种可观察的数据存储器类。与常规的可观察类不同,LiveData 具有生命周期感知能力,意指它遵循其他应用组件(如 Activity、Fragment 或 Service)的生命周期。这种感知能力可确保 LiveData 仅更新处于活跃生命周期状态的应用组件观察者。
注意:要将 LiveData 组件导入您的 Android 项目,请参阅向项目添加组件。
如果观察者(由 Observer 类表示)的生命周期处于 STARTED 或 RESUMED 状态,则 LiveData 会认为该观察者处于活跃状态。LiveData 只会将更新通知给活跃的观察者。为观察 LiveData 对象而注册的非活跃观察者不会收到更改通知。
您可以注册与实现 LifecycleOwner 接口的对象配对的观察者。有了这种关系,当相应的 Lifecycle 对象的状态变为 DESTROYED 时,便可移除此观察者。 这对于 Activity 和 Fragment 特别有用,因为它们可以放心地观察 LiveData 对象而不必担心泄露(当 Activity 和 Fragment 的生命周期被销毁时,系统会立即退订它们)。
要详细了解如何使用 LiveData,请参阅使用 LiveData 对象。
使用 LiveData 的优势
使用 LiveData 具有以下优势:
确保界面符合数据状态
LiveData 遵循观察者模式。当生命周期状态发生变化时,LiveData 会通知 Observer 对象。您可以整合代码以在这些 Observer 对象中更新界面。观察者可以在每次发生更改时更新界面,而不是在每次应用数据发生更改时更新界面。
不会发生内存泄露
观察者会绑定到 Lifecycle 对象,并在其关联的生命周期遭到销毁后进行自我清理。
不会因 Activity 停止而导致崩溃
如果观察者的生命周期处于非活跃状态(如返回栈中的 Activity),则它不会接收任何 LiveData 事件。
不再需要手动处理生命周期
界面组件只是观察相关数据,不会停止或恢复观察。LiveData 将自动管理所有这些操作,因为它在观察时可以感知相关的生命周期状态变化。
数据始终保持最新状态
如果生命周期变为非活跃状态,它会在再次变为活跃状态时接收最新的数据。例如,曾经在后台的 Activity 会在返回前台后立即接收最新的数据。
适当的配置更改
如果由于配置更改(如设备旋转)而重新创建了 Activity 或 Fragment,它会立即接收最新的可用数据。
共享资源
您可以使用单一实例模式扩展 LiveData 对象以封装系统服务,以便在应用中共享它们。LiveData 对象连接到系统服务一次,然后需要相应资源的任何观察者只需观察 LiveData 对象。有关详情,请参阅扩展 LiveData。
当然这些都是在谷歌开发者官网都是有的,我这里也搬运而已哈哈。
接下来开始我们的示例,首先我们创建LiveData对象
当然创建前我们首先要在gradle中引入依赖
// LiveData
implementation"androidx.lifecycle:lifecycle-livedata:$lifecycle_version"
创建LiveDataViewModel
public class LiveDataViewModel extends ViewModel {
private MutableLiveDatatickadd1,tickadd2;
//创建get方法
public MutableLiveDatagetTickadd1() {
if (tickadd1 ==null) {
tickadd1 =new MutableLiveData();
tickadd1.setValue(0);//设置初始值
}
return tickadd1;
}
//创建get方法
public MutableLiveDatagetTickadd2() {
if (tickadd2 ==null) {
tickadd2 =new MutableLiveData();
tickadd2.setValue(0);//设置初始值
}
return tickadd2;
}
//创建票数加1的方法
public void addTickadd1(){
if(tickadd1.getValue()!=null){tickadd1.setValue(tickadd1.getValue()+1);}
}
public void addTickadd2(){
if(tickadd2.getValue()!=null){tickadd2.setValue(tickadd2.getValue()+1);}
}
}
创建好的LiveDataViewModel之后我们开始创建Activity
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_live_data);
liveDataViewModel=new ViewModelProvider(this).get(LiveDataViewModel.class);
tv1=findViewById(R.id.tv1);
tv2=findViewById(R.id.tv2);//gfg
btn1=findViewById(R.id.btn1);
btn2=findViewById(R.id.btn2);
//观察者模式,检测数据的改变
liveDataViewModel.getTickadd1().observe(this, new Observer() {
@Override
public void onChanged(Integer integer) {
tv1.setText(String.valueOf(liveDataViewModel.getTickadd1().getValue()));
}
});
liveDataViewModel.getTickadd2().observe(this, new Observer() {
@Override
public void onChanged(Integer integer) {
tv2.setText(String.valueOf(liveDataViewModel.getTickadd2().getValue()));
}
});
//设置按钮的监听
btn1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
//直接调用viewModel中的方法
liveDataViewModel.addTickadd1();
}
});
btn2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
liveDataViewModel.addTickadd2();
}
});
}
}
然后是布局文件,布局文件跟我上一篇文章一样的我这里就不再多说了,
将这几步都完成了之后,那个恭喜你,LiveData的使用基本都完成了,接下来我们看运行的效果
可以看到效果基本达到了我们的预期:
我们在回过头来看这个示例,我们发现了时候LiveData之后在activity层的代码量有所减少,在activity中基本没有了数据的处理之类的代码了,更加专注于布局。将逻辑运算数据绑定转移到了viewMode层这样每一层就能更加专注处理自己的事务了。当然了我这里只是LiveData的简单使用,还有其他更多的妙用,等待了广大的大佬们去发掘了。哈哈!我们下一个模块见。