Java多线程编程-(7)-使用ReentrantReadWriteLock实现Lock并发
2017-10-12 00:00
639 查看
前几篇:
Java多线程编程-(1)-线程安全和锁Synchronized概念
Java多线程编程-(2)-可重入锁以及Synchronized的其他基本特性
Java多线程编程-(3)-从一个错误的双重校验锁代码谈一下volatile关键字
Java多线程编程-(4)-线程本地ThreadLocal的介绍与使用
Java多线程编程-(5)-线程间通信机制的介绍与使用
![](http://ss.csdn.net/p?http://mmbiz.qpic.cn/mmbiz_gif/UtWdDgynLdZPbGXJ7tibPmOS9a3OeSuSAbSEs3rff4AtFfNJk7G9GcPLvsjBzb575RgMONBslSDBHF5w2uyQDIQ/0?wx_fmt=gif&wxfrom=5&wx_lazy=1)
上一篇介绍了使用ReentrantLock实现同步互斥。
ReentrantLock具有完全互斥排他的效果,即同一时间只能有一个线程在执行ReentrantLock.lock()之后的任务。
类似于我们集合中有同步类容器 和 并发类容器,HashMap也是完全排他的,即使是读也只能同步执行,而ConcurrentHashMap就可以实现同一时刻多个线程之间并发。为了提高效率,ReentrantLock的升级版ReentrantReadWriteLock就可以实现效率的提升。
ReentrantReadWriteLock有两个锁:一个是与读相关的锁,称为“共享锁”;另一个是与写相关的锁,称为“排它锁”。也就是多个读锁之间不互斥,读锁与写锁互斥,写锁与写锁互斥。
在没有线程进行写操作时,进行读操作的多个线程都可以获取到读锁,而写操作的线程只有获取写锁后才能进行写入操作。即:多个线程可以同时进行读操作,但是同一时刻只允许一个线程进行写操作。
ReentrantReadWriteLock锁的特性
(1)读读共享;
(2)写写互斥;
(3)读写互斥;
(4)写读互斥;
读读共享-示例代码
![](http://ss.csdn.net/p?https://mmbiz.qpic.cn/mmbiz_png/UtWdDgynLdZPbGXJ7tibPmOS9a3OeSuSAcnjbLiandVp4CvRNeZvIHc0L3mfEfVuBavibyU78F2v6TcH8BrmYNicbA/0?wx_fmt=png)
可以看出两个线程之间,获取锁的时间几乎同时,说明
写写互斥-示例代码
![](http://ss.csdn.net/p?https://mmbiz.qpic.cn/mmbiz_png/UtWdDgynLdZPbGXJ7tibPmOS9a3OeSuSAYw4qjPkuGZ8CibRkqkLXaZbfzP1hqQybuKpAwayxR0FspSwicbUhngJQ/0?wx_fmt=png)
可以看出执行结果大致差了5秒的时间,可以说明多个写线程是互斥的。
读写互斥或写读互斥-示例代码
![](http://ss.csdn.net/p?https://mmbiz.qpic.cn/mmbiz_png/UtWdDgynLdZPbGXJ7tibPmOS9a3OeSuSA41fIVm0ibcomQ1KJibu20CHdhZiaoibtf8NNc5ibib30wT3soKX0gumDZWYg/0?wx_fmt=png)
![](http://ss.csdn.net/p?https://mmbiz.qpic.cn/mmbiz_png/UtWdDgynLdZPbGXJ7tibPmOS9a3OeSuSAQicvJDlJrEToPuBJqJcMYE1TQmwelVJhH7o8OmAtwn2icywQ3eBknl5Q/0?wx_fmt=png)
可以看出执行结果大致差了5秒的时间,可以说明读写线程是互斥的。
注:查看源代码请点击阅读原文,PC端效果更佳!
Java多线程编程-(1)-线程安全和锁Synchronized概念
Java多线程编程-(2)-可重入锁以及Synchronized的其他基本特性
Java多线程编程-(3)-从一个错误的双重校验锁代码谈一下volatile关键字
Java多线程编程-(4)-线程本地ThreadLocal的介绍与使用
Java多线程编程-(5)-线程间通信机制的介绍与使用
Java多线程编程-(6)-你还在使用wait/notify实现进程间的通信吗?
上一篇介绍了使用ReentrantLock实现同步互斥。
ReentrantLock具有完全互斥排他的效果,即同一时间只能有一个线程在执行ReentrantLock.lock()之后的任务。
类似于我们集合中有同步类容器 和 并发类容器,HashMap也是完全排他的,即使是读也只能同步执行,而ConcurrentHashMap就可以实现同一时刻多个线程之间并发。为了提高效率,ReentrantLock的升级版ReentrantReadWriteLock就可以实现效率的提升。
ReentrantReadWriteLock有两个锁:一个是与读相关的锁,称为“共享锁”;另一个是与写相关的锁,称为“排它锁”。也就是多个读锁之间不互斥,读锁与写锁互斥,写锁与写锁互斥。
在没有线程进行写操作时,进行读操作的多个线程都可以获取到读锁,而写操作的线程只有获取写锁后才能进行写入操作。即:多个线程可以同时进行读操作,但是同一时刻只允许一个线程进行写操作。
ReentrantReadWriteLock锁的特性
(1)读读共享;
(2)写写互斥;
(3)读写互斥;
(4)写读互斥;
读读共享-示例代码
可以看出两个线程之间,获取锁的时间几乎同时,说明
lock.readLock().lock();允许多个线程同时执行lock()方法后面的代码。
写写互斥-示例代码
可以看出执行结果大致差了5秒的时间,可以说明多个写线程是互斥的。
读写互斥或写读互斥-示例代码
可以看出执行结果大致差了5秒的时间,可以说明读写线程是互斥的。
注:查看源代码请点击阅读原文,PC端效果更佳!
相关文章推荐
- 聊聊高并发(二十九)解析java.util.concurrent各个组件(十一) 再看看ReentrantReadWriteLock可重入读-写锁
- 【Java并发编程实战】—–“J.U.C”:ReentrantReadWriteLock
- java多线程:并发包中ReentrantReadWriteLock读写锁的原理
- 多线程并发中ReentrantLock和ReentrantReadWriteLock的使用
- Java并发编程:重入锁(ReentranceLock )、读写锁(ReadWriteLock)代码实现
- 【Java并发编程实战】—–“J.U.C”:ReentrantReadWriteLock
- Java 并发问题的处理神器:ReentrantReadWriteLock
- Java并发学习(十三)-ReentrantReadWriteLock学习
- 「java.util.concurrent并发包」之 ReentrantReadWriteLock
- Android并发编程之如何使用ReentrantReadWriteLock替代synchronized来提高程序的效率
- 【Java并发编程实战】-----“J.U.C”:ReentrantReadWriteLock
- java 中 ReentrantReadWriteLock的读锁和写锁的使用
- java并发-锁-ReentrantLock(重入锁)和ReentrantReadWriteLock(读写锁)
- 【死磕Java并发】-----J.U.C之读写锁:ReentrantReadWriteLock
- 轻松掌握java读写锁(ReentrantReadWriteLock)的实现原理
- java多线程--ReentrantReadWriteLock的使用
- 聊聊高并发(二十九)解析java.util.concurrent各个组件(十一) 再看看ReentrantReadWriteLock可重入读-写锁
- java多线程学习10-使用ReentrantReadWriteLock的一个例子
- Java:多线程,线程同步,同步锁(Lock)的使用(ReentrantLock、ReentrantReadWriteLock)
- java并发中的ReentrantReadWriteLock