我的主要问题是“我是否真的需要重新检查以下代码中的 值 ”?
以下代码描述了如何使用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);
}
任何人都可以提供帮助吗?我是对的吗?我很困惑。
答案 0 :(得分:0)
是的,应该由多个线程同时读取读锁定 可能有一个线程正在执行第3行,而其他线程可能正在第2行中等待
但正如其他建议使用并发哈希图