当链路用 LiveData 表达时,访问数据库和网络的操作被定义在一个 Repository 的方法中:
class NewsRepository(context: Context) {
fun fetchNewsLiveData(): LiveData<List<News>?> {
// 1.从数据库获取新闻
val localNews = newsDao.queryNews()
// 2.从网络获取新闻
val remoteNews = newsApi.fetchNewsLiveData(mapOf("page" to "1", "count" to "4"))
// 3.将数据库和网络响应的 LiveData 合并
newsLiveData.addSource(localNews) {newsLiveData.value = it}
newsLiveData.addSource(remoteNews) {newsLiveData.value = it}
return newsLiveData
}
}
复制代码
并且它们是串行的,即只有当数据库访问结束后才开始网络请求,最后再将它们通过 MediatorLiveData 合流。
而使用流时,数据库和网络操作被定义在不同的流中,这为它们提供了更灵活的合流方式。
串行合流
串行合流的思路是将多个流组织成“嵌套流”,然后将它们“展平”。
拿 List 举例,List.flat()
提供了在列表上的展平操作,flat 即展平,为啥要展平?因为有嵌套,比如List<List<Int