LiveData 的更新值丢失

Kvd*_*gen 3 android android-livedata

LiveData 向上游传播数据是否有最短时间?

我有一个从存储库更新的 MutuableLiveData。更新代码从 Internet 加载一些数据并设置 MutuableLiveData 的值。下载发生在一个或多个 workerThreads 上,并且正在使用下载的数据对存储库进行回调。这是相关代码。我使用同步来防止线程同时尝试更改变量。

在存储库中:

@Override
public void returnResult(Schedule scheduleToReturn) {
     synchronized(this){
     mSecondaryWeekSchedule.postValue(scheduleToReturn)};
}
Run Code Online (Sandbox Code Playgroud)

在片段中:

mScheduleViewModel.getOverlayWeekSchedule().observe(getViewLifecycleOwner(), new Observer<Schedule>() {
        @Override
        public void onChanged(@Nullable Schedule schedule) {
            Log.d(DEBUGTAG, "Overlay weekschedule changed");
            Log.d(DEBUGTAG, ""+schedule.toString());
            addOverlay(schedule);
        }
    });
Run Code Online (Sandbox Code Playgroud)

getOverlayWeekSchedule 只是链接到存储库中的 liveData 变量。在存储库中设置适当的 Log.d() 我发现:

08-20 21:11:25.982 3001-3049/nl.kl_solutions.schedulecompareforzermelo D/ScheduleRepository:计划返回:Owner:hym WeekStart:03 Sep Events:19 08-20 21:11:20.013l.3k.3 schedulecompareforzermelo D/ScheduleRepository:计划返回:Owner:6409 WeekStart:03 Sep Events:27 08-20 21:11:26.348 3001-3001/nl.kl_solutions.schedulecompareforzermelo D/WeekScheduleFragment:03Sep16:26.348 3001-3001/nl.kl_solutions.schedulecompareforzermelo D/WeekScheduleFragment: Owner:6409 WeekStart:03 Sep Events:27

前两行来自,repository 显示了通过回调返回到不同线程上的存储库的时间表。最后两行是片段中观察者的一次触发,仅显示记录了对最后一个计划的更改。第一个变化在某处丢失了。

小智 9

根据设计,如果在主线程执行发布的任务之前多次调用 postValue,则只会调度最后一个值。

https://developer.android.com/reference/android/arch/lifecycle/LiveData.html#postValue(T)

有另一种不使用后期操作的 setValue 方法 - 要使用它,您需要确保在主线程上调用它。


Cit*_*sO2 5

就像 Chris 所说,您必须使用 setValue 来获取所有事件。但是您可以为此使用 Kotlin 的协程而不是 postValue,然后您将轻松获得所有更改(这是一个简单的重构):

//make sure you have a CoroutineScope to be able to use 'launch'
launch (Dispatchers.Main){ 
    yourMutableLiveData.value = "YourValueHere" 
}
Run Code Online (Sandbox Code Playgroud)