QuickCache缓存原理解析
来源:互联网 发布:临床药物查询软件 编辑:程序博客网 时间:2024/05/22 14:56
QuickCache前序
在写QuickCache之前,我也进行了诸多的思考和考量,更多的出发点是源于,到底有没有自己写QuickCache的必要性,于是我于是我查阅和研究了当前市面的所成型的缓存部分的技术,发现,还是有自己写一个的必要性,原因基于以下几点:
- 首先关于访问网络的请求,我本身在项目中所用的是okHttp,如果用ok的缓存机制,那就是用其拦截器进行缓存的相关操作;但是其本身只支持get访问的网络缓存,并不支持post访问的网络缓存,在使用该拦截器去执行POST请求的时候,会发现,即使在log中看到了读取缓存,但是实际上缓存目录里什么都没有。实际上是因为get请求一般较为持久,而post需要携带参数,会经常改动,所以没必要缓存,这个机制从Okhttp的源码里也可以看到:
//Cache类的put方法private CacheRequest put(Response response) throws IOException { String requestMethod = response.request().method(); if (HttpMethod.invalidatesCache(response.request().method())) { try { remove(response.request()); } catch (IOException ignored) { } return null; } //如果请求方式不用get,就直接跳过了 if (!requestMethod.equals("GET")) { return null; } //省略代码 }
- 现在有非常成熟的本地缓存操作框架DisLruCache,我也思考过用这个,但发现还是满足不了需求,原因是:
- DisLruCache其中并没有支持对不同账号下的数据进行缓存,不同账号下,相同的接口和请求参数返回的数据可能是不同的。
- DisLruCache 并没有对key进行别名设置的方法,当没有别名的情况下,在其他地方想对这一条缓存进行操作的话,可能便利性不是那么的高,复杂度和代码的冗余量也会有所增加。
- DisLruCache缓存在本地硬盘中,并没有对不同接口的缓存做目录区分,例如在listView或recyclerView等有分页缓存的情况下,当某页的某一条目被进行了删除操作,那么后面页缓存的数据与当前数据会有错位的情况,所以需要将当前所以缓存页进行清空重新获取,而DisLruCache实现起来同样复杂度也还是比较高
所以基于以上的考虑,于是就自己写了QuickCache。
gitHub(内含的Readme有相关调用的API文档)
优势:
- 可控于每一条缓存的时间,进行单独设定(通常的都是全局的设定,而这可以这条是时效性,那条三个小时,再一条八个小时。。等等)
- 可控于每一条缓存的管理,删除等操作,不单单是时间过期(通常的就是被动的时间过期进行删除,而这可主动进行管理)
- 有网络没网络都访问缓存,通过后台的推送更新缓存进行预加载
- 最大限度上,减轻了服务器的访问压力
- 最大限度上,减少了用户的流量使用
- 让用户感受到了极致加载体验
- 支持不同账号下的缓存
- 支持删除一个接口下的所有缓存
- 添加QucikCache之前动态GIF展示 -添加QucikCache之后动态GIF展示
用法
- AndroidStudio
allprojects { repositories { jcenter() <!--在项目的根gradle下添加如下这行代码--> maven{url 'https://jitpack.io'} }}
<!--项目的gradle下添加-->compile 'com.github.LiXiangABC:QuickCache:v2.0.1'
1.初始化QucikCache
##### 在 Application 中对 QuickCacheUtil 进行初始化
QuickCacheUtil.getInstance().setContext(getApplication();
2.使用QucikCache
示例:
<!--设置请求参数-->LinkedHashMap<String, String> mLinkedHashMap = new LinkedHashMap<String, String>(); mLinkedHashMap.put("ordercode", getArguments().getString("ordercode")); <!--调用LoadingCacheString()方法进行相关参数的设定--> QuickCacheUtil.getInstance().LoadingCacheString() .setTag(this) .setAlias(NetWorkURLBean.QUEUE_ORDER_INFO + getArguments().getString("ordercode")) .setRequestType(QuickCacheUtil.RequestType.post) .setUrl(NetWorkURLBean.QUEUE_ORDER_INFO) .setParams(mLinkedHashMap) .setIsOpenNetWork(true) .setIsRefreshCache(false) .setOrc(new onResponseCacheListener() { @Override public void onResponseCache(String onResponseData) { <!--在此执行获取到数据 onResponseData 的后续操作--> } } ).commit();
1.请求用到的API
QuickCacheUtil.getInstance().LoadingCacheString() 返回的 LoadingCacheStringBean API说明
2.对内存管理用到的一些API
QuickCacheUtil.getCacheManager() 返回的 CacheManager 提供的一些API说明
QuickCache内部结构UML原理解析
由于CSDN本身不支持UML中的一些功能,为了能够更好的展示清楚逻辑,放在了有道云上;【点击查看】—>QuickCache内部结构UML原理解析
QuickCache中ThreadTheTaskScheduler轮询原理与代码封装
QuickCache读取缓存的实现逻辑UML原理解析
由于CSDN本身不支持UML中的一些功能,为了能够更好的展示清楚逻辑,放在了有道云上;【点击查看】—>QuickCache读取缓存的实现逻辑UML原理解析
0 0
- QuickCache缓存原理解析
- 缓存原理解析
- HTTP协议缓存原理解析
- PHP Cache文件缓存机制与缓存原理解析
- Apache PHP利用HTTP缓存协议原理解析及应用
- Linux实现的ARP缓存老化时间原理解析
- [*] Linux实现的ARP缓存老化时间原理解析
- Linux实现ARP缓存老化时间原理问题深入解析
- 解析Android ListView工作原理及其缓存机制
- Sql Server tempdb原理-缓存机制解析实践
- Linux实现ARP缓存老化时间原理问题深入解析
- Linux实现的ARP缓存老化时间原理解析
- 缓存原理
- 缓存原理
- 秋色园QBlog技术原理解析:性能优化篇:缓存总有失效时,构造持续的缓存方案(十四)
- 秋色园QBlog技术原理解析:性能优化篇:缓存总有失效时,持续的缓存方案(十四)
- PHP如何利用HTTP缓存协议原理解析及应用指南
- Android 图片三级缓存加载框架原理解析与代码实现
- 关于 error: LNK1123: failure during conversion to COFF: file invalid or corrupt 错误的解决方案
- js的 nextsibling 和previousSibling
- DataBase can’t be open after shutdown immediate
- matlab二分类实验(使用libsvm工具包+SVMcgForClass函数)
- 冒泡排序和内置类比较排序操作
- QuickCache缓存原理解析
- Mac制作映像(dmg)文件详细步骤
- 窗体(文本框,按钮,单选按钮,标签)
- 通过HTTPS访问OSB
- superset 汉化
- 机器学习教程之5-神经网络:表述(Neural Networks:Representation)
- fedora20 配置java环境
- Mybatis(dao)实现举例
- 使用WinSXS进行系统盘瘦身Windows 7/2008/10/2012不断变大的C盘(Windows 更新清理)