gpt4 book ai didi

android - LiveData 的更新值丢失

转载 作者:行者123 更新时间:2023-12-04 23:43:15 34 4
gpt4 key购买 nike

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

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

在存储库中:

@Override
public void returnResult(Schedule scheduleToReturn) {
synchronized(this){
mSecondaryWeekSchedule.postValue(scheduleToReturn)};
}

在 fragment 中:
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);
}
});

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

08-20 21:11:25.982 3001-3049/nl.kl_solutions.schedulecompareforzermelo D/ScheduleRepository: schedule returned:Owner:hym WeekStart:03 Sep Events:19 08-20 21:11:26.015 3001-3065/nl.kl_solutions.schedulecompareforzermelo D/ScheduleRepository: schedule returned:Owner:6409 WeekStart:03 Sep Events:27 08-20 21:11:26.348 3001-3001/nl.kl_solutions.schedulecompareforzermelo D/WeekScheduleFragment: Overlay weekschedule changed 08-20 21:11:26.349 3001-3001/nl.kl_solutions.schedulecompareforzermelo D/WeekScheduleFragment: Owner:6409 WeekStart:03 Sep Events:27



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

最佳答案

按照设计,如果您在主线程执行发布的任务之前多次调用 postValue,则只会分派(dispatch)最后一个值。

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

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

关于android - LiveData 的更新值丢失,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51937241/

34 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com