在使用LiveData时,我无法了解MediatorLiveData的想法。在文档中提到MediatorLiveData是LiveData的子类,它将观察LiveData并对onChanged
方法做出反应。我的问题是,与在LiveData的observe
中具有功能并在新数据不同的情况下对数据进行处理有什么区别?
例如,假设我有一个来自Room Database的查询,该查询返回了如下的LiveData
@Query(“SELECT * FROM Users WHERE userid = :id”)
fun getUserById(id: String): LiveData<User>
如果我想使用MediatorLiveData
,可以使用以下扩展名
fun <T> LiveData<T>.distinctUntilChanged(): LiveData<T>{
var lastValue: Any? = Any()
return MediatorLiveData<T>().apply {
addSource(this@distinctUntilChanged){
if (it != lastValue){
lastValue = it
postValue(it)
}
}
}
}
然后在“活动”中将其用作
userDao.getUserById("someId").distinctUntilChanged()
.observe(this, user -> {/*Do something with user*/})
与上述情况相反,我可以在observe
方法内使用包装函数,如下所示:
var lastUser = null
userDao.getUserById("someId")
.observe(this, user -> {
if (lastUser != user){
lastUser = user
/*Do something with user*/
}
})
有人可以详细说明为什么我应该使用MediatorLiveData
而不是仅仅进行简单检查吗?