Android 学习日记----jetpack---androidx.LiveData

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的简单使用,还有其他更多的妙用,等待了广大的大佬们去发掘了。哈哈!我们下一个模块见。

你可能感兴趣的:(Android 学习日记----jetpack---androidx.LiveData)