如何在java中使用ReadWriteLock实现一个Cache?

时间:2015-10-15 15:24:47

标签: java dictionary readwritelock

我的主要问题是“我是否真的需要重新检查以下代码中的 ”?
以下代码描述了如何使用ReadWriteLock实现缓存。

public class ReadWriteLockCache {
private Map<String, Object> cache = new HashMap<String, Object>();
private ReadWriteLock rwl = new ReentrantReadWriteLock();

/**
 * @param args
 */
public static void main(String[] args) {
    // TODO Auto-generated method stub
}

public Object getData(String key) {
    rwl.readLock().lock();

    Object value = null;

    try {
        value = cache.get(key);

        if (value == null) {
            rwl.readLock().unlock(); //line1
            rwl.writeLock().lock(); //line2

            try {
                if (value == null) //line3
                 {
                    value = "aaaa"; // may get data from db
                                    //line5 put the data into cache.

                    cache.put(key, value);
                }
            } finally {
                rwl.writeLock().unlock();
            }

            rwl.readLock().lock();
        }
    } finally {
        rwl.readLock().unlock();
    }

    return value;
}

}

我是否还需要重新检查 'line3' 的值?

据我所知,当对象行3时,值对象必须为null,因为 它是一个局部变量 (当它为空时)并且它是大麻不是我们的主要obj的状态变量:ReadWriteLockCache 我们真正应该做的是 回想一下get方法,并检查键的值是否是其他线程推送的。

代码应该是这样的:

                    value = cache.get(key);
                if (value == null) //line3
                 {
                    value = "aaaa"; 
                    cache.put(key, value);
                }

任何人都可以提供帮助吗?我是对的吗?我很困惑。

1 个答案:

答案 0 :(得分:0)

是的,应该由多个线程同时读取读锁定 可能有一个线程正在执行第3行,而其他线程可能正在第2行中等待

但正如其他建议使用并发哈希图