面试题:用读写锁写一个缓存

本文介绍了一种使用读写锁实现的缓存机制,通过读写锁的切换确保了多线程环境下数据的一致性和安全性。当读取缓存中的数据时,首先尝试获取读锁;若数据不存在,则释放读锁并尝试获取写锁,从数据库中加载数据后再重新获取读锁,以减少锁的竞争。
private Map<String,Object> cache = new HashMap<String,Object>();
private ReadWriteLock rwl = new ReentrantReadWriteLock();
public Object getData(String key) {
	rwl.readLock().lock();
	Object value = null;
	try {
		value = cache.get(key);
		//value为空再去写
		if(value == null) {
			//读锁先解锁
			rwl.readLock().unlock();
			//再上写锁,多个线程时,第一个线程先加锁,其他的先等待
			rwl.writeLock().lock();
			try {
				//如果多个线程进来,第一个线程先执行,执行完之后value不为null,所以这里
				//判断一次是为了后面的线程来执行时不用再去写。
				if(value == null) {
					value = "aaaa";//实际是去queryDB();
				}
			}finally {
				//写完释放写锁
				rwl.writeLock().unlock();
			}
			//再上读锁
			rwl.readLock().lock();
		}
	} finally {
		//读锁解锁
		rwl.readLock().unlock();
	}
	return value;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值