Java多线程并发之读写锁

本文主要内容:读写锁的理论;通过生活中例子来理解读写锁;读写锁的代码演示;读写锁总结。通过理论(总结)-例子-代码-然后再次总结,这四个步骤来让大家对读写锁的深刻理解。

本篇是《凯哥(凯哥Java:kagejava)并发编程学习》系列之《Lock系列》教程的第七篇:《Java并发包下锁学习第七篇:读写锁》。

一:读写锁的理论

什么是读写锁?

多个线程同时读一个资源类是没有任何问题的,所以为了满足在并发的情况下,读取共享资源应该是可以同时进行的;但是,如果一个线程想要去写共享资源,就不应该再有其他线程可以对该共享资源进行读或者是写操作了。

即读写锁在同一时刻可以允许多个多线程访问,但是在写线程访问的时候,所有的读线程和其他写线程都会被阻塞。读写锁实际维护了一对锁,一个读锁,一个写锁,通过分离读锁和写锁,使得其并发性比独占式锁(排他锁)有了很大的提升。

为什么需要读写锁?

通过前面文章的学习,我们知道了ReentrantLock(下文简称:RLock)对象了。Rlock比起synchronized(下文简称Sync)来说有三个优点:RLock可以被中断;RLock可以有公平锁;RLock可以绑定多个条件。那么既然RLock比Sync有这么多优点,为什么还需要读写锁呢?

那是因为RLock是独占式(排他) 锁,即当线程1获取到资源的时候,其他线程不能再来操作共享资源了。就算是RLock的操作是读取的时候,其他线程也不能读取共享资源的操作。这在现实生活中是不符合逻辑的(在下文神话中读写锁的例子中我们就能体会到为什么不符合逻辑的),而且性能也比较慢。所以就有了读写锁的出现。

二:读写锁的理解

生活中读写锁的例子

例子一:我们大家去火车站乘车的时候,有个大大的公示屏幕,会告诉大家当前车次是否晚点。显示屏是给给所有乘客看的,如果火车晚点,对应车次后面就会被修改成晚点大约xxx分钟。这个修改的动作只能是火车站内部人员来操作的,我们乘客是不能操作的。这个过程,站在并发角度来分析的的话:电子屏幕是共享数据;千千万万的乘客是不同的线程;火车站内部工作人员也是不同的线程;乘客是读资源的线程,当一个线程来读取的时候,其他线程也可以读取操作的;火车站内部工作人员修改火车信息的时候,同时只能有一个工作人员来修改,不能两个都来修改。如果两个都来修改的话,上一秒显示晚点1min,下一秒显示正常。这个是不行的,乘客有可能会错过乘车的。所以修改的时候同时只能由一个工作人员来修改。

例子二:我们在玩王者荣耀的时候,有时候会遇到停服更新的。在不更新前,所有玩家都可以玩,当停服更新的时候,所有玩家就不能玩了。这个操作在并发角度来说:千千万万的玩家是读共享资源的;游戏维护者是写操作的。当停服更新的时候,读操作就被阻塞了,只能等写操作,也就是更新完成后,才可以接着玩。

通过上面两个例子我们可以分析到读写锁的三个参与者:共享资源;读对象;写对象。而且读和写一般是分离的。

三:读写锁的代码演示

我们就用火车站进站案例来模拟:

未使用锁的时候

先来看看屏幕对象:

再来看看多个工作人员更新操作及多个乘客获取操作:

查看运行结果:

从运行结果中,我们可以发现当工号未13的还没有更新完车次信息的时候,工号12和14的员工也来更新了。这种操作是不允许的。因为写操作要原子性,要独占。当工作人员甲在修改的时候车次信息的时候,其他工作人员不能同时修改同一个车次信息了。而且从乘客获取车次信息的数据来看,获取到的只是工号是13的。这个时候获取到的数据不一定是正确的了。所以,不使用锁是不行的。

使用排他锁

如果使用独占式做的话,我们查看运行结果:

从运行结果来看,再读取的时候,需要一个一个读取的。当16号乘客查看的时候,17号乘客是不能查看的。这个是不符合实际业务逻辑的。所以,独占式(排他锁)RLock在这里不适合。我们再来看看读写锁:

使用读写锁

先来看看使用读写锁的屏幕对象

再来看看运行结果:

从运行结果中,我们可以看到,工作人员是一个一个的操作完成的。当14号操作完成之后,13号和12号才可以操作的。这个符号我们正常的业务。乘客读取的时候,读取到的都是最后一次更新,这个也符合我们的业务。所以,通过读写锁来操作车站屏幕是可以的。

四:读写锁总结

4.1:wrLock类对象

同样包含了公平锁和非公平锁。

其中ReadLock是读锁对象;WriteLock是写锁对象。

4.2:使用语法

读操作使用ReadLock

编辑

写操作的时候,使用WriteLock对象:

4.3:总结

读写锁(ReentrantReadWriteLock),凯哥就简写rwLock。也可以实现公平和非公平的。其内部维护了一对锁:一个读锁(ReadLock对象),一个写锁(writeLock对象),通过读写分离的方式来提高并发性能。读写锁也叫共享锁。其共享是在读数据的时候,可以让多个线程同时进行读操作的。在写的时候具有排他性,其他读或者写操作都要被阻塞。

一般情况下,读写锁的性能都会比排他锁性能好,那是因为,大多数场景读操作多于写操作的。在读多与写的场景下,读写锁能够提供比排他锁更好的并性能和吞吐量。

​    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​    ​欢迎来聊~

java车次信息_从火车站车次公示栏来学Java读写锁相关推荐

  1. java写车次查询_从火车站车次公示栏来学Java读写锁

    Java多线程并发之读写锁 本文主要内容:读写锁的理论:通过生活中例子来理解读写锁:读写锁的代码演示:读写锁总结.通过理论(总结)-例子-代码-然后再次总结,这四个步骤来让大家对读写锁的深刻理解. 本 ...

  2. java 配置信息_[Java教程]java 配置信息类 Properties 的简单使用

    [Java教程]java 配置信息类 Properties 的简单使用 0 2016-12-08 09:00:09 Properties :(配置信息类) 是一个表示持久性的集合 ,继承 Hashta ...

  3. java 异常信息_优雅的异常处理 -- Java中的异常

    处理异常自己处理 try-catch抛出让别人处理 throws 获得异常信息 直接打印异常对象 通过异常对象调用getMessage()方法获得 通过异常对象调用printStackTrace()方 ...

  4. java 堆栈信息_每天学习一个命令:jstack 打印 Java 进程堆栈信息

    Jstack 用于打印出给定的 java 进程 ID 或 core file 或远程调试服务的 Java 堆栈信息. 这里需要注意的是 Java 8 引入了 Java Mission Control, ...

  5. java syn包_月薪3K的后端面试点-网络与Java

    网络基础 传输控制协议TCP简介 面向连接的.可靠的.基于字节流的传输层通信协议 将应用层的数据流分割成报文段并发送给目标节点的TCP层 数据包都有序号,对方收到则发送ACK确认,未收到则重传 使用校 ...

  6. 公需科目必须学吗_会计继续教育公需课必须学吗?

    目前2020年已开通地区的会计继续教育已经开始,学员可以按部就班进行继教课程学习了,有些学员会问到:继续教育公需课必须学吗?针对这个问题,由于会计继续教育实行是属地管理原则,所以不同地区对公需课程的要 ...

  7. 北京待售商品房数量信息将在网上全面公示

    本报讯(记者 蒋彦鑫)来自北京 市建委的统计显示,截至4月30日,北京可售的期房项目共计1512个,其中待售面积1541.39万平方米:待售现房289.14万平方米,二者相加已经达1830万平方米.北 ...

  8. activiti 设置候选人_中标 | 河南移动公示无源波分复用设备集采中标候选人名单:3家厂商上榜...

    新闻导读 河南移动2020-2021年无源波分复用设备采购项目共有广东九联科技.光迅科技及烽火通信等3家厂商上榜中标候选人名单.该项目拟采购12200套无源波分复用设备,94800个彩光模块及安装配件 ...

  9. opencv3 java开发手册_介绍一本opencv不错的书-OpenCV3使用Java开发手册

    你们好 http://www.topteam.cc/02-shop-detail.php?cid=&sid=&pid=896 Opencv 不但有趣并且是免费的视觉相关开发软体,它可以 ...

最新文章

  1. 自动 Android* 应用测试
  2. 演讲:创新思维框架(2016/北京/国家会议中心)
  3. python怎么和sql一起用_自己写的Python数据库连接类和sql语句拼接方法
  4. xaml中的布局面板
  5. 【Java每日一题】20170302
  6. 荷兰商业银行使用精益领导力推行改进
  7. 科发财务凭证登陆出现错误:40002
  8. python_机器学习(一)、基本概念
  9. 大数据学习资源(上)
  10. 利用ENVI自带全球DEM数据计算区域平距高程
  11. linux下建立无线wifi------简单实用!
  12. Python 搜狗词库的批量下载
  13. Openproj 在64位操作系统报错errno=193
  14. Wireshark实验
  15. 8. Celery 4.3.0 Periodic Tasks 周期性任务调度
  16. 数据透视:Excel数据透视和Python数据透视
  17. java开发中常用插件三----blockui
  18. 系统迁移性能问题解决
  19. EXT3文件系统修复
  20. 极验滑块验证码破解与研究(二):缺口图片还原

热门文章

  1. 题目:16版.雇员的工作职责(一)
  2. Spring MVC 测试 | 模拟提交表单
  3. linux下c 编译脚本,Linux下编译C语言与makefile脚本语言
  4. python读取图像数据流_浅谈TensorFlow中读取图像数据的三种方式
  5. 【转】如何开始学习CoreCLR源代码?
  6. Web Reference和Service Reference的区别
  7. VBA类之一(初识类)
  8. php记录登录时间,php记录 用户当前页面停留时间
  9. golang 包含 数组_Golang数组类型
  10. ios开发问题汇总(一)