RxCache使用注解為Retrofit的請求API配置緩存信息,職責清晰。在對緩存的處理時,使用動態(tài)代理對數(shù)據(jù)請求進行介入。
動態(tài)代理
RxCache創(chuàng)建API訪問接口事例采用動態(tài)代理模式。在執(zhí)行網(wǎng)絡請求之前,檢查是否從緩存中讀取;網(wǎng)絡請求之后,進行自定義的緩存操作。
動態(tài)代理機制
代理類在運行時生成,也就是說Java編譯完之后并沒有實際的class文件,而在運行時動態(tài)生成的類字節(jié)碼,并加載到JVM中。
靜態(tài)代理類的實現(xiàn)又很多共性(重復代碼),動態(tài)代理可以避免這些重復代碼,只需關(guān)注操作。
動態(tài)代理利用反射,為動態(tài)生成的代理類增加了InvocationHandler調(diào)用處理器。也就是說InvocationHandler承擔了對委托類的干預操作,如訪問控制、遠程通信、日志、緩存等。參考 & 成富大佬的深度歷險JAVA系列
擴展:類型擦除機制
具體表現(xiàn)就是類型參數(shù)只存在于編譯期,在運行時,Java 的虛擬機 ( JVM )。 并不知道泛型的存在。Java的泛型機制是在編譯級別實現(xiàn)的。編譯器生成的字節(jié)碼在運行期間并不包含泛型的類型信息,編譯器在編譯生成的字節(jié)碼文件中插入了類型轉(zhuǎn)換的代碼。
數(shù)組在運行期間知道每個元素的類型且強制它們的元素為該類型.
擴展:工廠模式
簡單工廠模式:提供一個工廠負責制造多類型的產(chǎn)品,工廠是全能類
工廠模式:多個工廠各自負責單一類型產(chǎn)品的構(gòu)建,工廠為單一職責
抽象工廠模式:如果工廠的產(chǎn)品全部屬于同一個等級結(jié)構(gòu)則屬于工廠模式,如果來自多個等級結(jié)構(gòu)則屬于抽象工廠模式。
構(gòu)造者模式:當多個子部分可以組成不同的產(chǎn)品時,使用構(gòu)造者模式對產(chǎn)品構(gòu)建邏輯進行封裝。
RxJava中的defer及flatmap操作符
在對緩存進行獲取和存儲時,使用RxJava語法進行操作。
defer
just(),from(),和其他Observable創(chuàng)建的工具在創(chuàng)建Observable時會存儲當前的數(shù)據(jù),而不是在subscribe()的時候.但是使用create()和defer()是可以的。
Observable.defer(() -> Observable.just(value));
但是defer()比Observable.create()更簡單,不會調(diào)用onCompleted(),defer()的缺點是當有新的訂閱者時它每次都會創(chuàng)建Observable,create()則會使用相同的Observable。flatMapdoesn't guarantee any order,butconcatMapcan.