RxCache 用于 Android 和 Java 的响应式缓存库开源项目

我要开发同款
匿名用户2018年01月23日
33阅读
开发技术Java
所属分类程序开发、缓存系统
授权协议Apache 2.0

作品详情

RxCache 是一个用于Android和Java的响应式缓存库,可将缓存需求转换为一个接口进行配置。

RxCache的灵感来源于 Retrofit ,目标是像 Picasso 缓存图片一样,毫不费力缓存数据对象。

当提供一个 observable、 single、 maybe 或 flowable 这些由耗时操作提供的数据时,RxCache会确定是否需要subscribe,或覆盖先前缓存的数据。此决定是基于RxCache的Providers进行配置的。

架构图:

Usage

使用尽可能多的方法定义 interface来创建Provider以缓存数据:

interface Providers {        @ProviderKey("mocks")        Observable<List<Mock>> getMocks(Observable<List<Mock>> oMocks);            @ProviderKey("mocks-5-minute-ttl")        @LifeCache(duration = 5, timeUnit = TimeUnit.MINUTES)        Observable<List<Mock>> getMocksWith5MinutesLifeTime(Observable<List<Mock>> oMocks);            @ProviderKey("mocks-evict-provider")        Observable<List<Mock>> getMocksEvictProvider(Observable<List<Mock>> oMocks, EvictProvider evictProvider);            @ProviderKey("mocks-paginate")        Observable<List<Mock>> getMocksPaginate(Observable<List<Mock>> oMocks, DynamicKey page);            @ProviderKey("mocks-paginate-evict-per-page")        Observable<List<Mock>> getMocksPaginateEvictingPerPage(Observable<List<Mock>> oMocks, DynamicKey page, EvictDynamicKey evictPage);                @ProviderKey("mocks-paginate-evict-per-filter")        Observable<List<Mock>> getMocksPaginateWithFiltersEvictingPerFilter(Observable<List<Mock>> oMocks, DynamicKeyGroup filterPage, EvictDynamicKey evictFilter);}
声明:本文仅代表作者观点,不代表本站立场。如果侵犯到您的合法权益,请联系我们删除侵权资源!如果遇到资源链接失效,请您通过评论或工单的方式通知管理员。未经允许,不得转载,本站所有资源文章禁止商业使用运营!
下载安装【程序员客栈】APP
实时对接需求、及时收发消息、丰富的开放项目需求、随时随地查看项目状态

评论