一.简单介绍

client缓存机制不仅能够减轻server端的压力,同一时候也能让用户在网速较慢的情况下获取良好的用户体验。

所以构建一个优秀的APP,缓存是非常重要的一个环节。



二.处理方案

client从server获取最新数据,假如是20条,同一时候将数据缓存到本地,当载入下一页数据时不仅将数据加入到内存中。还要同步到缓存中。

这样以此类推,内存中的数据和缓存的数据保持一致。


当用户又一次下拉刷新界面时,会出现两种情况:
一种是此时用户数据更改小于一页。另外一种是用户数据更改大于一页。


第一种情况比較简单。数据变动小于一页。说明刷新返回的数据加上缓存的数据就能够构建出用户的所有数据,所以此时仅仅须要合并刷新返回的最新数据和缓存的数据,将反复的数据去掉就可以。

另外一种情况比較复杂。数据变动大于一页,说明刷新返回数据和缓存数据之间还遗漏了部分的数据,那怎样去同步这部分的数据呢?
简单的方案是,假设出现这样的情况,则重构缓存。重构缓存的意思就是删除旧的缓存信息又一次加入建立缓存。这个方法的长处就是实现简单不easy出错,当然缺点就是假设频繁的重构缓存则失去了缓存的意义。
真正的解决中间数据获取的问题。能够通过新建暂时的数组的方式。将当前在内存中的数据放入暂时的变量中,然后把刷新返回的数据增加内存中,当用户触发载入很多其它事件时,推断最新返回的数据是不是和暂时变量中的数据有重合,有重合说明中间的遗漏数据已经获取完成,则将暂时变量的数据合并到内存中就可以。当然内存中的操作都须要同步到缓存中。

用户每次又一次进入该模块都会先从缓存中载入数据到内存,然后自己主动获取最新的数据与内存中的数据合并就可以。

若用户网络不通的情况下直接展示缓存数据。


三.问题

上述方案中会遇到下面几个问题:

  1. 载入很多其它时。传入分页的page和size,当用户数据频繁的更新时。会出现冗余的数据,比方第一页的最后两条可能就是第二页的前两条。

  2. 同步问题,在有些业务中,数据大部分是不变的,可是有些数据是会变化的,比方在微博中,微博内容不会变化,可是转发条数,评论数是在变化的。假设只展示缓存中的数据会出现和server端不同步的问题
  3. 缓存没有一个清理功能。随着时间的增长,总会出现内存溢出的情况
解决:
问题1:获取数据时分页中增加sinceID和maxID。用以来控制最大和最小的数据ID。这样就能防止冗余的反复数据
问题2:对于频繁的小数据块(如阅读数。分享数)能够制定同步协议,更新这些小数据块时无需更新总体的数据
问题3:内存的增长能够通过限制缓存的条数来控制,当缓存条数超过限制后。为用户重构缓存(大数据块的更新也能够通过定时重构缓存来实现)



异常处理:
网络异常--显示缓存数据
内存溢出--限制缓存条数

client缓存机制的更多相关文章

  1. hibernate缓存机制(转)

    原文出处:http://www.cnblogs.com/wean/archive/2012/05/16/2502724.html 一.why(为什么要用Hibernate缓存?) Hibernate是 ...

  2. JPA,EclipseLink 缓存机制学习(一) 树节点搜索问题引发的思考

    最近在项目在使用JPA+EclipseLink 的方式进行开发,其中EclipseLink使用版本为2.5.1.遇到一些缓存方面使用不当造成的问题,从本篇开始逐步学习EclipseLink的缓存机制. ...

  3. 浏览器 HTTP 协议缓存机制详解

    最近在准备优化日志请求时遇到了一些令人疑惑的问题,比如为什么响应头里出现了两个 cache control.为什么明明设置了 no cache 却还是发请求,为什么多次访问时有时请求里带了 etag, ...

  4. 理解 QEMU/KVM 和 Ceph(1):QEMU-KVM 和 Ceph RBD 的 缓存机制总结

    本系列文章会总结 QEMU/KVM 和 Ceph 之间的整合: (1)QEMU-KVM 和 Ceph RBD 的 缓存机制总结 (2)QEMU 的 RBD 块驱动(block driver) (3)存 ...

  5. Hibernate 缓存机制

    一.why(为什么要用Hibernate缓存?) Hibernate是一个持久层框架,经常访问物理数据库. 为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能. 缓存内的数据是对物理数 ...

  6. 进击的Hybrid App,量身定做缓存机制

    引用张图,简单粗俗的解释下 Native App.Web App 和 Hybrid App Navtie App: 使用平台系统提供的原生语言来编写的 App,如果Android用java,ios用o ...

  7. [http] http缓存机制

    原文链接:http://my.oschina.net/leejun2005/blog/369148 1.缓存的分类 缓存分为服务端侧(server side,比如 Nginx.Apache)和客户端侧 ...

  8. Hibernate 缓存机制二(转)

    感谢:http://www.cnblogs.com/wean/archive/2012/05/16/2502724.html 一.why(为什么要用Hibernate缓存?) Hibernate是一个 ...

  9. hibernate中的缓存机制

    一.为什么要用Hibernate缓存? Hibernate是一个持久层框架,经常访问物理数据库. 为了降低应用程序对物理数据源访问的频次,从而提高应用程序的运行性能. 缓存内的数据是对物理数据源中的数 ...

随机推荐

  1. Android仿苹果版QQ下拉刷新实现(二) ——贝塞尔曲线开发"鼻涕"下拉粘连效果

    前言 接着上一期Android仿苹果版QQ下拉刷新实现(一) ——打造简单平滑的通用下拉刷新控件 的博客开始,同样,在开始前我们先来看一下目标效果: 下面上一下本章需要实现的效果图: 大家看到这个效果 ...

  2. 一步一步学习IdentityServer3 (2)

    下面就来做一个例子:IdentityServer3服务端的配置 VS2015创建一个MVC项目 IdrOAuth 用来授权的认证的站点

  3. fpm制作rpm包

    一.前言 在企业中我们有事安装软件包.部分都是源码安装,如nginx安装路径都已经固化了,但实际业务中,我们都是把软件包安装到固定目录下,不满足需要,这是其一.其二,编译安装很耗时,比如mysql,特 ...

  4. MySQL子查询,派生表和通用表达式

    一:子查询 1.介绍 在另一个查询(外部查询)中嵌套另一个查询语句(内部查询),并使用内部查询的结果值作为外部查询条件. 2.子查询在where中 SELECT customerNumber, che ...

  5. Python 项目实践二(生成数据)第二篇

    接着上节继续学习,在本节中,我们将使用Python来生成随机漫步数据,再使用matplotlib以引人瞩目的方式将这些数据呈现出来.随机漫步是这样行走得到的路径:每次行走都完全是随机的,没有明确的方向 ...

  6. windows10 下安装tensorflow 并且在jupyter notebook 上使用tensorflow

    一.安装jupyter notebook并配置环境 首先建议大家安装anaconda,最新版本请到官网下载(点击下载连接),没错,直接点击下载python3.6版本的(当然选择做自己电脑相应的位数,我 ...

  7. 网络与多线程---OC中多线程方法GCD(二)

    小编在前一篇中介绍了多线程实现的五种常用方法.在接下来所介绍的这种方法是最具有魅力的,最具有诱惑的实现多线程的方案---GCD 一.什么是GCD GCD是Grand Central Dispatch的 ...

  8. 二叉查找树(二叉排序树)的详细实现,以及随机平衡二叉查找树Treap的分析与应用

    这是一篇两年前写的东西,自我感觉还是相当不错的Treap教程.正好期末信息科学技术概论课要求交一个论文,就把这个东西修改了一下交了,顺便也发到这里吧. 随机平衡二叉查找树Treap的分析与应用 1.序 ...

  9. Message Queue协议AMQP

    历史: Message Queue的需求由来已久,80年代最早在金融交易中,高盛等公司采用Teknekron公司的产品,当时的Message queuing软件叫做:the information b ...

  10. ubuntu下smokeping安装配置

    0.参考文件 http://wenku.baidu.com/view/950fbb0a79563c1ec5da71b1 http://aaaxiang000.blog.163.com/blog/sta ...