RxCache使用注解为Retrofit的请求API配置缓存信息,职责清晰。在对缓存的处理时,使用动态代理对数据请求进行介入。
动态代理
RxCache创建API访问接口事例采用动态代理模式。在执行网络请求之前,检查是否从缓存中读取;网络请求之后,进行自定义的缓存操作。
动态代理机制
代理类在运行时生成,也就是说Java编译完之后并没有实际的class文件,而在运行时动态生成的类字节码,并加载到JVM中。
静态代理类的实现又很多共性(重复代码),动态代理可以避免这些重复代码,只需关注操作。
动态代理利用反射,为动态生成的代理类增加了InvocationHandler调用处理器。也就是说InvocationHandler承担了对委托类的干预操作,如访问控制、远程通信、日志、缓存等。参考 & 成富大佬的深度历险JAVA系列
扩展:类型擦除机制
具体表现就是类型参数只存在于编译期,在运行时,Java 的虚拟机 ( JVM )。 并不知道泛型的存在。Java的泛型机制是在编译级别实现的。编译器生成的字节码在运行期间并不包含泛型的类型信息,编译器在编译生成的字节码文件中插入了类型转换的代码。
数组在运行期间知道每个元素的类型且强制它们的元素为该类型.
扩展:工厂模式
简单工厂模式:提供一个工厂负责制造多类型的产品,工厂是全能类
工厂模式:多个工厂各自负责单一类型产品的构建,工厂为单一职责
抽象工厂模式:如果工厂的产品全部属于同一个等级结构则属于工厂模式,如果来自多个等级结构则属于抽象工厂模式。
构造者模式:当多个子部分可以组成不同的产品时,使用构造者模式对产品构建逻辑进行封装。
RxJava中的defer及flatmap操作符
在对缓存进行获取和存储时,使用RxJava语法进行操作。
defer
just()
,from()
,和其他Observable
创建的工具在创建Observable
时会存储当前的数据,而不是在subscribe()
的时候.但是使用create()
和defer()
是可以的。
Observable.defer(() -> Observable.just(value));
但是defer()
比Observable.create()
更简单,不会调用onCompleted()
,defer()
的缺点是当有新的订阅者时它每次都会创建Observable
,create()
则会使用相同的Observable
。flatMap
doesn't guarantee any order,butconcatMap
can.