读写锁之ReadWriteLock

Posted amberjava

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了读写锁之ReadWriteLock相关的知识,希望对你有一定的参考价值。

你可能有这样一个疑问,Java SDK 并发包里为什么还有很多其他的工具类呢?原因很简单:分场景优化性能,提升易用性

接下来我们聊聊,针对读多写少这种并发场景,Java SDK 并发包提供了读写锁——ReadWriteLock
读写锁,并不是 Java 语言特有的,而是一个广为使用的通用技术,所有的读写锁都遵守以下三条,尤其注意第三条,之后我们讲跟其他锁的对比会用到。
基本原则:
1. 允许多个线程同时读共享变量;
2.只允许一个线程写共享变量;
3. 如果一个写线程正在执行写操作,此时禁止读线程读共享变量(读写锁不能同时存在)
 

互斥锁:

 

 
 

 

 

互斥锁

互斥锁

升降级

ReadWriteLock

读操作允许多个线程同时读共享变量

写操作是互斥的,当一个

线程在写共享变量的时候,是不允许其他线程执行写操作和读操作。

 

不允许升级,允许降级。

读锁不支持条件变量newCondition()

 

 

 
 
读写锁在读多写少场景下性能优于互斥锁的关键
 
总结:
读写锁类似于 ReentrantLock,也支持公平模式和非公平模式。读锁和写锁都实现了
java.util.concurrent.locks.Lock 接口,所以除了支持 lock() 方法外,tryLock()、
lockInterruptibly() 等方法也都是支持的。但是有一点需要注意,那就是只有写锁支持条件变量,
读锁是不支持条件变量的,读锁调用 newCondition() 会抛出 UnsupportedOperationException
异常
 
 
 

以上是关于读写锁之ReadWriteLock的主要内容,如果未能解决你的问题,请参考以下文章

JAVA 并发编程-读写锁之模拟缓存系统

Java并发程序设计(15)并发锁之读写锁(续二)写锁降级

锁之ReentrantLock

锁之synchronized

001Java锁之synchronized

C# 多线程锁之ReaderWriterLockSlim