一.简单介绍

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. plaidctf-2016 Pwn试题小结

    回顾了一下今年plaidctf Pwn部分的题目,感觉还是蛮有意思的,值得研究一下. 1.unix_time_formatter-76 最简单的一道题,考点是UAF.说是UAF但是其实根本就不算是真正 ...

  2. Angular快速学习笔记(4) -- Observable与RxJS

    介绍RxJS前,先介绍Observable 可观察对象(Observable) 可观察对象支持在应用中的发布者和订阅者之间传递消息. 可观察对象可以发送多个任意类型的值 -- 字面量.消息.事件. 基 ...

  3. NET Core中使用Angular2的Token base身份认证

    下载本文提到的完整代码示例请访问:How to authorization Angular 2 app with asp.net core web api 在ASP.NET Core中使用Angula ...

  4. 配置Gitlab使用LDAP认证

    1. 通过SSH登陆Gitlab服务器. 2. 进行以下配置文件夹. [root@c720141 ~]# cd /etc/gitlab/ 3. 打开gitlab.rb配置文件,并加入以下配置. git ...

  5. Eclipse添加SVN插件:导入项目+上传项目+更新项目

    首先在Eclipse中安装SVN插件,方法同安装Pydev相同 首先点击help,然后点击Install New Software 然后在弹出的窗口中点击Add,再在新弹出的窗口中的url栏输入如下内 ...

  6. rabbitmq学习(八) —— 可靠机制上的“可靠”

    接着上一篇,既然已经有了手动ack.confirm机制.return机制,还不够吗? 以下博文转自https://www.jianshu.com/p/6579e48d18ae和https://my.o ...

  7. 循序渐进学.Net Core Web Api开发系列【14】:异常处理

    系列目录 循序渐进学.Net Core Web Api开发系列目录 本系列涉及到的源码下载地址:https://github.com/seabluescn/Blog_WebApi 一.概述 本篇介绍异 ...

  8. 子域名枚举工具Sublist3r

    子域名枚举工具Sublist3r   通过搜集子域名信息,可以找到目标的关联网站,找寻相应的漏洞.Kali Linux提供一款基于OSINT的枚举工具Sublist3r.该工具会搜索多个数据来源,如G ...

  9. 前端网页、php与mysql数据库字符编码(解决中文等乱码问题)

    web开发中经常涉及前端网页——php——mysql之间的数据交互,当数据只有英文时通常不会有什么问题,但一旦涉及中文,三个地方的某一处字符编码不一致(如,网页使用的时gbk而mysql使用utf-8 ...

  10. 怎样c# java md5值保持一致

    c#方式 /// <summary> /// 获得字符串md5. /// </summary> /// <param name="myString"& ...