首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 软件管理 > 软件架构设计 >

【叨、校长】java缓存范例、自己做的一个缓存实例

2012-11-19 
【叨、校长】java缓存实例、自己做的一个缓存实例自己写的一个缓存类、通俗易懂、老少皆宜!--叨、校长package com

【叨、校长】java缓存实例、自己做的一个缓存实例

自己写的一个缓存类、通俗易懂、老少皆宜!--叨、校长

package com.master.common;import java.util.List;/** * 一个缓存实例 * @example  *  String name="test"; *  List list=null; *CacheData c=CacheData.matchCahceData(name); *if(c.getData()==null){ *list=jokeService.findJokeList();//从数据库获取数据 *c.setData(list); *}else{ *list=c.getData(); *} * @author 叨、校长 * @datatime 2012-11-04 */public class CacheData{//最大缓存记录private final static int MAX_SIZE=10;private static CacheData[] datas=new CacheData[MAX_SIZE];//每条缓存的名称private final String name;//每条缓存的数据private List data=null;//使用单例模式、防止外部实例化该类private CacheData(String name){this.name=name;}public String getName(){return name;}public List getData(){return data;}public void setData(List data) {this.data = data;}//判读缓存中是否有该名称的记录,如果没有则添加缓存实例并且返回该缓存实例//如果缓存满了,则把第一条记录更新为新缓存,并且返回该缓存实例public static CacheData matchCahceData(String name){CacheData cache;int i=0;int j=1;for(;i<MAX_SIZE;i++){if(datas[i]!=null){if(datas[i].getName().equals(name)){return datas[i];}j++;}}cache=new CacheData(name);if(j==MAX_SIZE){datas[0]=cache;}else{datas[j--]=cache;}return cache;}}
?

?

1 楼 lpy3654321 前天   是什么思路'能说说吗 2 楼 wb1991wb 前天   就是用一个数组就存储频繁读取的数据、加假如有一个频繁的查询功能、则把第一次读取的数据保存在服务端的内存里面、下次读取直接从内存里面拿! 3 楼 wb1991wb 前天   lpy3654321 写道是什么思路'能说说吗
就是用一个数组就存储频繁读取的数据、加假如有一个频繁的查询功能、则把第一次读取的数据保存在服务端的内存里面、下次读取直接从内存里面拿! 4 楼 shanhucc 昨天   果然是老少皆宜···· 5 楼 w156445045 昨天   没看懂是啥意思,哈哈。。 6 楼 realskyzou 昨天   额。。。这太搞笑了吧。。。 7 楼 zhukewen_java 昨天   有缓存的意识是件好事,不过楼主的缓存效率上会有点问题。每次取的时候都要遍历整个数组,size小倒没事,如果大了,就会比较慢了。一般缓存都是用map来存的。 8 楼 lhm20092003023 昨天   写得不错,不过 1.有没考虑过内存问题呢?是否可以使用软引用。 2.这里用list做缓存不太适合吧?这样遍历效率比较低。 9 楼 wb1991wb 昨天   lhm20092003023 写道写得不错,不过 1.有没考虑过内存问题呢?是否可以使用软引用。 2.这里用list做缓存不太适合吧?这样遍历效率比较低。
数组的性能比map高吧! 10 楼 wb1991wb 昨天   数组的性能比map高吧!lhm20092003023 写道写得不错,不过 1.有没考虑过内存问题呢?是否可以使用软引用。 2.这里用list做缓存不太适合吧?这样遍历效率比较低。
数组的性能比map高吧! 11 楼 zhukewen_java 23 小时前   wb1991wb 写道数组的性能比map高吧!lhm20092003023 写道写得不错,不过 1.有没考虑过内存问题呢?是否可以使用软引用。 2.这里用list做缓存不太适合吧?这样遍历效率比较低。
数组的性能比map高吧!
建议楼主写个邮件给memcached团队和apache团队和很多其它的团队,叫他们把缓存由map改为数组。

热点排行