0°

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

内容预览:
  • 为了提高效率,ReentrantLock的升级版ReentrantReadWriteLock就可以实现...~
  • 在没有线程进行写操作时,进行读操作的多个线程都可以获取到读锁,而写...~
  • 即:多个线程可以同时进行读操作,但是同一时刻只允许一个线程进行写操作~

始发于微信公众号: Java后端技术

前几篇:


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

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

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

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

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

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

ReentrantReadWriteLock锁的特性

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

读读共享-示例代码

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

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

写写互斥-示例代码

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

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

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

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

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

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

注:查看源代码请点击阅读原文,PC端效果更佳!

和大佬一起学习网络安全知识

以上就是:Java多线程编程-(7)-使用ReentrantReadWriteLock实现Lock并发 的全部内容

本站部分内容来源于互联网和用户投稿,如有侵权请联系我们删除,谢谢^^
Email:[email protected]


0 条回复 A 作者 M 管理员
    所有的伟大,都源于一个勇敢的开始!
欢迎您,新朋友,感谢参与互动!欢迎您 {{author}},您在本站有{{commentsCount}}条评论