线程之缓存demo

import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.locks.ReadWriteLock;
import java.util.concurrent.locks.ReentrantReadWriteLock;

public class CacheDemo {

    /**
     * 缓存:就是一个对象把数据(从数据库或是文件...)拿到,等待另外的对象来取数据
     * 如果存在就直接取走,不存在则查询数据库或文件...
     * 
     */
    
    private static Map<String, Object> map = new HashMap<String, Object>();
    
    private static ReadWriteLock rwl = new ReentrantReadWriteLock();
    
    public static void main(String[] args) {
        
    }
    
    public static Object demo(String key){
        Object object ;
        rwl.readLock().lock(); //读的时候加读锁
        try{
            object = map.get(key);
            if(object == null){
                rwl.readLock().unlock();//如果没有数据,读锁打开,加上写锁
                rwl.writeLock().lock();//加写锁
                try{
                    if(object == null){//这里的判断是防止在第一个线程写过后,第二个线程有来写(因为第一个写过后就有了,就用不着写了)
                        object = "it is not null";//实际情况这里是不应该直接赋值的,应该操作数据库或是文件等
                    }
                }finally{
                    rwl.writeLock().unlock();//第一个线程写完了,写锁打开,并上读锁
                    rwl.readLock().lock();//上读锁
                }
            }
        }finally{
            rwl.readLock().unlock();//读完了打开读锁
        }
        return object;
    }

}

 

posted @ 2014-03-16 00:00  huidaoli  阅读(213)  评论(0编辑  收藏  举报