读写锁之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的主要内容,如果未能解决你的问题,请参考以下文章