Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Why does LiveData better than MutableLiveData?

In many samples i see that:

 class DataViewModel{
         val data:LivaData<Int>
             get() = _data 

         private val _data = MutableLiveData<Int>()

    }

But more simply looks like this:

 class DataViewModel{
         val data = MutableLiveData<Int>()

    }

so, why need this more complicated code construction with 2 fields?

like image 687
Serg Burlaka Avatar asked Oct 17 '25 10:10

Serg Burlaka


2 Answers

It's a practice designed to restrict modification of the value from outside the class.

LiveData is read-only. MutableLiveData, as the name implies, allows one to change the value it holds.

If you expose a MutableLiveData directly, like in your second example, any code which can access that data field could also modify the value it holds.

Exposing the ability to change data's content from outside DataViewModel class could make it harder to debug and reason about where data's content is coming from at any given time.

like image 140
jensck Avatar answered Oct 20 '25 00:10

jensck


MutableLiveData is essentially a LiveData with public access to two methods setValue() and postValue() for modifying that data.

Therefore, MutableLiveData is needed if you plan to modify the values of the LiveData.

However, in programming, it's a common concept to make your variables immutable or restrict the access of those who can modify the data of an object. You wouldn't want to expose the ability to modify the contents of variables within an object if there's no need to do so.

Therefore, for MutableLiveData, we normally use a getter to get it's parent form, which is LiveData.

By getting only LiveData, we can ensure that those who access the LiveData object can only read the values stored within with no ability to change them.

In a sense, it's just the concept of why you should use private variables with getters.

like image 27
Jackey Avatar answered Oct 20 '25 00:10

Jackey



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!