首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用Coroutines实现分页库2边界回调?

如何使用Coroutines实现分页库2边界回调?
EN

Stack Overflow用户
提问于 2021-08-30 15:12:55
回答 1查看 160关注 0票数 1

我希望使用分页库2使用协同、liveData和存储库模式来实现我的自定义liveData,但是我找不到这些库集成的好例子。

即使在Android官方样本中,它们也使用队列和回调来执行分页2的API请求.

我也读过这个介质帖子,但是它在边界回调中使用了一个协同作用域,我认为这不是一个好的实践。

有什么办法可以做到吗?还是我应该迁移到第3页?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-09-01 15:38:06

这个解决方案适用于我:

  1. 我在我的仓库里注射了一个CoroutinesDispatcherProvider: 类MyRepository @Inject构造函数(私有val remoteDataSource: MyRemoteDataSource,私有val localDataSource: MyDao,私有val coroutinesDispatcherProvider: CoroutinesDispatcherProvider ){.}
  2. 然后,在我的存储库中,我将这个提供程序传递给我的边界回调: 私人val boundaryCallback = MyBoundaryCallback(remoteDataSource,localDataSource,coroutinesDispatcherProvider) getList():LiveData = LivePagedListBuilder( localDataSource.getAll(),pagedListConfig getList)
  3. 最后,我在边界实现中使用这个dispatcher从存储库启动请求: 由惰性{ CoroutineScope(coroutinesDispatcherProvider.io) }覆盖乐趣onZeroItemsLoaded() { ioCoroutineScope.launch { remoteDataSource.getList() }}的私有val ioCoroutineScope
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68986397

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档