java缓存的简单实现

package com.qinbo.hui;

  public class CacheConfModel implements java.io.Serializable{

  private long beginTime;

  private boolean isForever = false;

  private int durableTime;

  public long getBeginTime() {

  return beginTime;

  }

  public void setBeginTime(long beginTime) {

  this.beginTime = beginTime;

  }

  public boolean isForever() {

  return isForever;

  }

  public void setForever(boolean isForever) {

  this.isForever = isForever;

  }

  public int getDurableTime() {

  return durableTime;

  }

  public void setDurableTime(int durableTime) {

  this.durableTime = durableTime;

  }

  }

  package com.qinbo.hui;

  import java.util.*;

  import test4.CacheConfModel;

  /*

  设计思想来自-回钦波(qq:444084929)

  */

  public class CacheMgr {

  private static Map cacheMap = new HashMap();

  private static Map cacheConfMap = new HashMap();

  private CacheMgr(){

  }

  private static CacheMgr cm = null;

  public static CacheMgr getInstance(){

  if(cm==null){

  cm = new CacheMgr();

  Thread t = new ClearCache();

  t.start();

  }

  return cm;

  }

  /**

  * 增加缓存

  * @param key

  * @param value

  * @param ccm 缓存对象

  * @return

  */

  public  boolean addCache(Object key,Object value,CacheConfModel ccm){

  boolean flag = false;

  cacheMap.put(key, value);

  cacheConfMap.put(key, ccm);

  System.out.println("now addcache=="+cacheMap.size());

  return true;

  }

  /**

  * 删除缓存

  * @param key

  * @return

  */

  public  boolean removeCache(Object key){

  cacheMap.remove(key);

  cacheConfMap.remove(key);

  System.out.println("now removeCache=="+cacheMap.size());

  return true;

  }

  /**

  * 清除缓存的类

  * @author wanglj

  * 继承Thread线程类

  */

  private static class ClearCache extends Thread{

  public void run(){

  while(true){

  Set tempSet = new HashSet();

  Set set = cacheConfMap.keySet();

  Iterator it = set.iterator();

  while(it.hasNext()){

  Object key = it.next();

  CacheConfModel ccm = (CacheConfModel)cacheConfMap.get(key);

  //比较是否需要清除

  if(!ccm.isForever()){

  if((new Date().getTime()-ccm.getBeginTime())>= ccm.getDurableTime()*60*1000){

  //可以清除,先记录下来

  tempSet.add(key);

  }

  }

  }

  //真正清除

  Iterator tempIt = tempSet.iterator();

  while(tempIt.hasNext()){

  Object key = tempIt.next();

  cacheMap.remove(key);

  cacheConfMap.remove(key);

  }

  System.out.println("now thread================>"+cacheMap.size());

  //休息

  try {

  Thread.sleep(60*1000L);

  } catch (InterruptedException e) {

  // TODO Auto-generated catch block

  e.printStackTrace();

  }

  }

  }

  }

  }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
java缓存实现demo完整实例,很不错的资源,欢迎大家来下载学习。/** * 此函数接受一个对象列表,数目不定,opration:表是触发的事件 * eg:change;fnClear:表示初始化下拉框。var_args表示多个下拉框... */ function bindSelects(operation, initSelectObj, loadShow, var_args){ //每个argument对象都有一个 change事件 //change事件会触发:此argument之后的对象清空,紧跟此对象的后一对象发送ajax请求 var elementList = []; for (var i = 3; arguments[i]; i++) { elementList[i-3] = arguments[i]; } for (var i = 0; elementList[i]; i++) { (function(k) { elementList[k].bind(operation, function(){ selectType = elementList[k].attr("name"); //其后的对象进行某个操作 for (var j = k+1; elementList[j]; j++) { if (initSelectObj && initSelectObj.constructor===Function) { if(elementList[k].val() == "") { initSelectObj(elementList[j],elementList[j].data(SELECT_KEY)); LOAD_KEYS[j].hide(); } else{ initSelectObj(elementList[j],elementList[j].data(SELECT_KEY)); } } } //紧跟对象发送ajax if (elementList[k+1]) { if(elementList[k].val() != "") { //从页面缓存中取出 if(elementList[k+1].data(elementList[k].val())) { var data = elementList[k+1].data(elementList[k].val()); var key=LIST_KEYS[k]; var jsonKey = [key]; addContentToSelect(data,jsonKey,elementList[k+1]); } else { //从缓存中取出数据 if (fnAjax && fnAjax.constructor===Function) { loadShow(LOAD_KEYS[k+1]); fnAjax(elementList[k+1].data(SELECT_KEY),LIST_KEYS[k],LOAD_KEYS[k+1],elementList[k],selectType); } } } } }); })(i); } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值