首页
学习
活动
专区
圈层
工具
发布
20 篇文章
1
Java多线程编程-(20)-借ThreadLocal出现OOM内存溢出问题再谈弱引用WeakReference
2
Java多线程编程-(19)-多线程异步调用之Future模式
3
Java多线程编程-(18)-等待/通知模式接口Condition接口深入分析
4
Java多线程编程-(17)-读写锁ReentrantReadWriteLock深入分析
5
Java多线程编程-(16)-无锁CAS操作以及Java中Atomic并发包的“18罗汉”
6
Java多线程编程-(15)- 关于锁优化的几点建议
7
Java多线程编程-(14)-Java中的队列同步器AQS和ReentrantLock锁原理简要分析
8
Java多线程编程-(13)-从volatile和synchronized的底层实现原理看Java虚拟机对锁优化所做的努力
9
Java多线程编程-(12)-单例模式几种写法的错与对
10
Java多线程编程-(11)-面试常客ThreadLocal出现OOM内存溢出的场景和原理分析
11
Java多线程编程-(10)-看了这篇关于ThreadLocal的原理应该透彻了
12
Java多线程编程-(9)-使用线程池实现线程的复用和一些坑的避免
13
Java多线程编程-(8)-两种常用的线程计数器CountDownLatch和循环屏障CyclicBarrier
14
Java多线程编程-(7)-使用ReentrantReadWriteLock实现Lock并发
15
Java多线程编程-(6)-你还在使用wait/notify实现进程间的通信吗?
16
Java多线程编程-(5)-线程间通信机制的介绍与使用(温馨提示:图文较多,建议Wiff下打开)
17
Java多线程编程-(4)-线程本地ThreadLocal的介绍与使用
18
Java多线程编程-(3)-从一个错误的双重校验锁代码谈一下volatile关键字
19
Java多线程编程-(2)-可重入锁以及Synchronized的其他基本特性
20
Java多线程编程-(1)-线程安全和锁Synchronized概念

Java多线程编程-(7)-使用ReentrantReadWriteLock实现Lock并发

上一篇介绍了使用ReentrantLock实现同步互斥。

ReentrantLock具有完全互斥排他的效果,即同一时间只能有一个线程在执行ReentrantLock.lock()之后的任务。

类似于我们集合中有同步类容器并发类容器,HashMap也是完全排他的,即使是读也只能同步执行,而ConcurrentHashMap就可以实现同一时刻多个线程之间并发。为了提高效率,ReentrantLock的升级版ReentrantReadWriteLock就可以实现效率的提升。

ReentrantReadWriteLock有两个锁:一个是与读相关的锁,称为“共享锁”;另一个是与写相关的锁,称为“排它锁”。也就是多个读锁之间不互斥,读锁与写锁互斥,写锁与写锁互斥。

在没有线程进行写操作时,进行读操作的多个线程都可以获取到读锁,而写操作的线程只有获取写锁后才能进行写入操作。即:多个线程可以同时进行读操作,但是同一时刻只允许一个线程进行写操作。

ReentrantReadWriteLock锁的特性

(1)读读共享; (2)写写互斥; (3)读写互斥; (4)写读互斥;

读读共享-示例代码

可以看出两个线程之间,获取锁的时间几乎同时,说明lock.readLock().lock(); 允许多个线程同时执行lock()方法后面的代码。

写写互斥-示例代码

可以看出执行结果大致差了5秒的时间,可以说明多个写线程是互斥的。

读写互斥或写读互斥-示例代码

可以看出执行结果大致差了5秒的时间,可以说明读写线程是互斥的。

下一篇
举报
领券