缓存功能(简单的synchronized和使用读写锁)

本文深入探讨了在并发编程中如何利用`synchronized`关键字与读写锁来优化多线程间的资源访问,减少竞态条件并提高性能。通过实例展示了在缓存类中使用这两种机制实现高效、安全的数据同步。

使用synchronized:

class MyCache{
	private Map<String,Object> cache = new HashMap<String,Object>();
	public synchronized Object getObject(String key){
		//加上锁是为了避免多个线程在得到的value都为null时,都同时去访问数据库
		Object value=cache.get(key);
		if(value==null){
			value="aaaaa";//其实是从数据库中得到相关的记录
			cache.put(key, value);
		}
		return value;
	}
}
使用读写锁:

class MyCache1{
	private Map<String,Object> cache = new HashMap<String,Object>();
	private ReadWriteLock rwl = new ReentrantReadWriteLock();
	public Object getObject(String key){
		rwl.readLock().lock();
		Object value=cache.get(key);
		if(value==null){
			rwl.readLock().unlock();//必须首先解锁才能获取写锁
			rwl.writeLock().lock();
			if(value==null){//这里为什么还要判断,避免多个写锁被阻塞(因为只能有一个写锁是互斥的)的时候,重复对value进行赋值,从而访问数据库
				value="aaaaa";//其实是从数据库中得到相关的记录
				cache.put(key, value);
			}
			//对锁进行降级,把写锁降级为读锁
			rwl.readLock().lock();//重新获取读锁不放弃写锁
			rwl.writeLock().unlock();//写锁解除,读锁仍在
		}
		rwl.readLock().unlock();
		return value;
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值