美文网首页Android之Jetpack篇Android专题
LiveData与MutableLiveData的区别

LiveData与MutableLiveData的区别

作者: 千夜零一 | 来源:发表于2020-10-01 12:59 被阅读0次

    区别

    LiveData与MutableLiveData的其实在概念上是一模一样的.唯一的几个区别如下:

    (1)MutableLiveData的父类是LiveData;
    (2)LiveData在实体类里可以通知指定某个字段的数据更新;
    (3)MutableLiveData则是完全是整个实体类或者数据类型变化后才通知.不会细节到某个字段。


    用法

    第一步:创建MutableLiveData

    public class DemoViewModel extends ViewModel {
        // TODO: Implement the ViewModel
        private MutableLiveData<String> myString = new MutableLiveData<>();
    
        public MutableLiveData<String> getMyString(){
            return myString;
        }
    
        public void setMyString(String string) {
            this.myString.setValue(string);
        }
    }
    

    第二步:在ViewModel里实例化MutableLiveData

    因为MutableLiveData只是作用于变量所以我们直接就可以在ViewModel里实例化它,并且在泛型里标注变量的类型。

    public class MutableLiveData<T> extends LiveData<T> {
        @Override
        public void postValue(T value) {
            super.postValue(value);
        }
    
        @Override
        public void setValue(T value) {
            super.setValue(value);
        }
    }
    

    第三步:在Activity或者Fragment绑定

    public class Demo1Activity extends AppCompatActivity {
        private static final String TAG = "Demo1Activity";
        private DemoViewModel mDemoViewModel;
        private Button mBtn1;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.activity_demo);
            mBtn1 = findViewById(R.id.btn_1);
            mDemoViewModel = ViewModelProviders.of(this).get(DemoViewModel.class);//获取ViewModel,让ViewModel与此activity绑定
            mDemoViewModel.getMyString().observe(this, new Observer<String>() { //注册观察者
                @Override
                public void onChanged(String s) {
                    Log.e(TAG, "onChanged: 值有变化="+s);
                }
            });
    
            mBtn1.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    mDemoViewModel.setMyString("测试"); //用手动按键点击改变值
    
    
                }
            });
        }
    }
    

    第四步:结果。当点击按键后就会有数据更新后的回调触发。

    2019-09-18 19:59:38.294 6961-6961/demo.yt.com.demo E/Demo1Activity: onChanged: 值有变化=测试
    

    【API解析】

    postValue()
    

    可能你已经在上面看到几次调用此方法了。postValue的特性如下:

    1.此方法可以在其他线程中调用

    2.如果在主线程执行发布的任务之前多次调用此方法,则仅将分配最后一个值。

    3.如果同时调用 .postValue(“a”)和.setValue(“b”),一定是值b被值a覆盖。


    setValue()
    

    setValue()的特性如下:

    1.此方法只能在主线程里调用


    removeObserver(@NonNull final Observer<? super T> observer)
    

    移除指定的观察者
    例子:

    Observer<String> observer = new Observer<String>() {
                @Override
                public void onChanged(String s) {
                    mText.setText("内容改变=" + s);
                }
            };
            mMainViewModel.getContent().observe(this, observer);//绑定
            mMainViewModel.getContent().removeObserver(observer);//解除
    

    removeObservers(@NonNull final LifecycleOwner owner)
    

    移除当前Activity或者Fragment的全部观察者


    observe(@NonNull LifecycleOwner owner, @NonNull Observer<? super T> observer)
    

    设置此LiveData数据当前activity或者Fragment的观察者,会给此activity或者Fragment在前台时回调数据。


    observeForever(@NonNull Observer<? super T> observer)
    

    1.设置永远观察者,永远不会被自动删除。您需要手动调用removeObserver(Observer)以停止观察此LiveData,

    2.设置后此LiveData,一直处于活动状态,不管是否在前台哪里都会获得回调。

    相关文章

      网友评论

        本文标题:LiveData与MutableLiveData的区别

        本文链接:https://www.haomeiwen.com/subject/osxjuktx.html