根据某种条件定时删除Map中的key

原创 2006年06月25日 22:18:00
根据某种条件定时删除Map中的key,主要用于一些定时删除key的操作
应该是在模仿httpsession的环境中应用比较多
package pack;
import java.util.HashMap;
import java.util.Map;
/**
 *
 * @author Administrator
 *
 */
public abstract class ExecuteTimeTask extends Thread {
 
 private long time=60*100;//定时时间
 private Map map=null;
 /**
  * condition is true, execute the clean operation
  * @param key
  * @param value
  * @return
  */
 public abstract boolean condition(Object key,Object value);
 
 
 
 
 /* (non-Javadoc)
  * @see java.lang.Thread#run()
  */
 public void run() {
  for(;;){
   //
   try {
    synchronized (this) {
     this.wait(time);
    }    
   } catch (InterruptedException e) {
    e.printStackTrace();
   }
   
   if(map==null||map.size()<1){
    continue;
   }
   
   for(java.util.Iterator it=map.entrySet().iterator();it.hasNext();){
     Map.Entry entry=(Map.Entry)it.next();
     if(condition(entry.getKey(),entry.getValue())){
      it.remove();
     };
    
    
   }
  
   
  }
 }

 /**
  * @param args
  */
 public static void main(String[] args) {
  ExecuteTimeTask t=new ExecuteTimeTask(){
   public boolean condition(Object key, Object value) {
    return key.toString().equals(value.toString())?true:false;
    //return true;
   }
   
  };
  Map m=new HashMap();
  m.put("a", "2");
  //m.put("2", "2");
  t.setMap(m);
  t.setTime(1000);
  
  
  t.start();
  long l=0;
   for(;;){
   
    try {
     synchronized (Thread.currentThread()) {
      Thread.currentThread().wait(2000);
     }   
    } catch (InterruptedException e) {
     // TODO Auto-generated catch block
     e.printStackTrace();
    }
     System.err.println("before--"+m+"---"+java.lang.Runtime.getRuntime().totalMemory());
  m.put(l+"", l+"");
  l++;
  System.err.println("after"+m+"---nanotime--"+System.nanoTime()+"-----"+System.currentTimeMillis());
   }
  
 }

 /**
  * @return the map
  */
 public Map getMap() {
  return map;
 }

 /**
  * @param map the map to set
  */
 public void setMap(Map map) {
  this.map = map;
 }

 /**
  * @return the time
  */
 public long getTime() {
  return time;
 }

 /**
  * @param time the time to set
  */
 public void setTime(long time) {
  this.time = time;
 }
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

java Map定时过期类

package com.ltx.system.util; import java.util.Date; import java.util.HashMap; import java.util.Iter...

Map中删除数据 或是key

在Map中直接删除内容将抛出 java.util.ConcurrentModificationException 异常,如果要删除可以用Iterator的remove()方法。 以下代码报错: ...

Map集合中的方法(添加、删除、判断、获取)

/* Map集合:该集合存储键(K)值(V)对,一对一往里存,而且要保证键的唯一性。 1、添加 put(K key,V value) putAll(Map m) 2、删除 ...

标准C++实现key-value数据插入及修改的简单例子

在统计文本数据时,经常会出现一些key-value结构的数据,并且需要进行动态的修改,下面为用c++标准程序库实现的一个操作key-value结构数据的简单例子。 #include #include...

分享一个java Map实现的cache manager,定时清除缓存起来的值

分享一个java Map实现的cache manager,定时清除缓存起来的值 源代码下载地址:http://www.zuidaima.com/share/1550463676140544.htm

[C++11 并发编程] 11 - 线程间同步 - 等待一个消息或某种条件

上一节,我们了解了如何对线程之间的共享资源进行保护的方法。但是,有些时候,我们需要在线程之间进行同步操作。一个线程等待另一个线程完成某项工作后,再继续自己的工作。比如,某个线程需要等待一个消息,或者某...

Java根据条件删除Map中元素

今天在写程序过程中,需要根据判断条件删除一个Map中的相应数据,我自然而然想到可以通过调用Map中的remove(Object key)函数进行删除:代码如下: public Map process...

Spark根据key,按照一定条件对数据去重

使用groupByKey和reduceByKey,将数据按照某一特定条件去重
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)