MutableLiveData

public class MutableLiveData<T> extends LiveData

Object
   ↳ LiveData
     ↳ MutableLiveData
Known direct subclasses
MediatorLiveData

LiveData subclass which may observe other LiveData objects and react on OnChanged events from them.


LiveData which publicly exposes setValue and postValue method.

Parameters
<T>

The type of data hold by this instance

Summary

Public constructors

Creates a MutableLiveData with no value assigned to it.

MutableLiveData(T value)

Creates a MutableLiveData initialized with the given value.

Public methods

@Override void
postValue(T value)

Posts a task to a main thread to set the given value.

@Override void
setValue(T value)

Sets the value.

Inherited methods

From class LiveData
@Nullable T

Returns the current value.

boolean

Returns true if this LiveData has active observers.

boolean

Returns true if this LiveData has observers.

@MainThread void

Adds the given observer to the observers list within the lifespan of the given owner.

@MainThread void

Adds the given observer to the observers list.

void

Called when the number of active observers change from 0 to 1.

void

Called when the number of active observers change from 1 to 0.

@MainThread void

Removes the given observer from the observers list.

@MainThread void

Removes all observers that are tied to the given LifecycleOwner.

Public constructors

MutableLiveData

public MutableLiveData()

Creates a MutableLiveData with no value assigned to it.

MutableLiveData

public MutableLiveData(T value)

Creates a MutableLiveData initialized with the given value.

Parameters
T value

initial value

Public methods

postValue

@Override
public void postValue(T value)

Posts a task to a main thread to set the given value. So if you have a following code executed in the main thread:

liveData.postValue("a");
liveData.setValue("b");
The value "b" would be set at first and later the main thread would override it with the value "a".

If you called this method multiple times before a main thread executed a posted task, only the last value would be dispatched.

Parameters
T value

The new value

setValue

@Override
public void setValue(T value)

Sets the value. If there are active observers, the value will be dispatched to them.

This method must be called from the main thread. If you need set a value from a background thread, you can use postValue

Parameters
T value

The new value