`
raymond.chen
  • 浏览: 1417619 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

ReentrantReadWriteLock的使用

 
阅读更多

ReentrantReadWriteLock会使用两把锁来解决问题,一个读锁,一个写锁。

ReadLock排斥WriteLock不排斥ReadLock,即多个读锁不互斥;WriteLock则既排斥WriteLock又排斥ReadLock。

WriteLock可以降级为ReadLock,顺序是:先获得WriteLock再获得ReadLock,然后释放WriteLock。

 

在多线程环境下,读取多写入很少的情况下,使用 ReentrantReadWriteLock 可能会使写入线程遭遇饥饿(Starvation)问题,也就是写入线程无法竞争到锁定而一直处于等待状态。

 

private Object data = null;//共享数据,只能有一个线程能写该数据,但可以有多个线程同时读该数据。
private ReentrantReadWriteLock rwl = new ReentrantReadWriteLock();
 
public void get(){
	rwl.readLock().lock();//上读锁,其他线程只能读不能写
	try {
		do something
	} catch (InterruptedException e) {
		e.printStackTrace();
	} finnaly {
		rwl.readLock().unlock(); //释放读锁
	}
}
 
public void put(Object data){
	rwl.writeLock().lock();//上写锁,不允许其他线程读也不允许写                  
	try {
	this.data = data;
	} catch (InterruptedException e) {
		e.printStackTrace();
	} finnaly {
		rwl.writeLock().unlock();//释放写锁 
	}    
}

 

0
2
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics