java车次信息_从火车站车次公示栏来学Java读写锁
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读写锁相关推荐
- java写车次查询_从火车站车次公示栏来学Java读写锁
Java多线程并发之读写锁 本文主要内容:读写锁的理论:通过生活中例子来理解读写锁:读写锁的代码演示:读写锁总结.通过理论(总结)-例子-代码-然后再次总结,这四个步骤来让大家对读写锁的深刻理解. 本 ...
- java 配置信息_[Java教程]java 配置信息类 Properties 的简单使用
[Java教程]java 配置信息类 Properties 的简单使用 0 2016-12-08 09:00:09 Properties :(配置信息类) 是一个表示持久性的集合 ,继承 Hashta ...
- java 异常信息_优雅的异常处理 -- Java中的异常
处理异常自己处理 try-catch抛出让别人处理 throws 获得异常信息 直接打印异常对象 通过异常对象调用getMessage()方法获得 通过异常对象调用printStackTrace()方 ...
- java 堆栈信息_每天学习一个命令:jstack 打印 Java 进程堆栈信息
Jstack 用于打印出给定的 java 进程 ID 或 core file 或远程调试服务的 Java 堆栈信息. 这里需要注意的是 Java 8 引入了 Java Mission Control, ...
- java syn包_月薪3K的后端面试点-网络与Java
网络基础 传输控制协议TCP简介 面向连接的.可靠的.基于字节流的传输层通信协议 将应用层的数据流分割成报文段并发送给目标节点的TCP层 数据包都有序号,对方收到则发送ACK确认,未收到则重传 使用校 ...
- 公需科目必须学吗_会计继续教育公需课必须学吗?
目前2020年已开通地区的会计继续教育已经开始,学员可以按部就班进行继教课程学习了,有些学员会问到:继续教育公需课必须学吗?针对这个问题,由于会计继续教育实行是属地管理原则,所以不同地区对公需课程的要 ...
- 北京待售商品房数量信息将在网上全面公示
本报讯(记者 蒋彦鑫)来自北京 市建委的统计显示,截至4月30日,北京可售的期房项目共计1512个,其中待售面积1541.39万平方米:待售现房289.14万平方米,二者相加已经达1830万平方米.北 ...
- activiti 设置候选人_中标 | 河南移动公示无源波分复用设备集采中标候选人名单:3家厂商上榜...
新闻导读 河南移动2020-2021年无源波分复用设备采购项目共有广东九联科技.光迅科技及烽火通信等3家厂商上榜中标候选人名单.该项目拟采购12200套无源波分复用设备,94800个彩光模块及安装配件 ...
- opencv3 java开发手册_介绍一本opencv不错的书-OpenCV3使用Java开发手册
你们好 http://www.topteam.cc/02-shop-detail.php?cid=&sid=&pid=896 Opencv 不但有趣并且是免费的视觉相关开发软体,它可以 ...
最新文章
- 自动 Android* 应用测试
- 演讲:创新思维框架(2016/北京/国家会议中心)
- python怎么和sql一起用_自己写的Python数据库连接类和sql语句拼接方法
- xaml中的布局面板
- 【Java每日一题】20170302
- 荷兰商业银行使用精益领导力推行改进
- 科发财务凭证登陆出现错误:40002
- python_机器学习(一)、基本概念
- 大数据学习资源(上)
- 利用ENVI自带全球DEM数据计算区域平距高程
- linux下建立无线wifi------简单实用!
- Python 搜狗词库的批量下载
- Openproj 在64位操作系统报错errno=193
- Wireshark实验
- 8. Celery 4.3.0 Periodic Tasks 周期性任务调度
- 数据透视:Excel数据透视和Python数据透视
- java开发中常用插件三----blockui
- 系统迁移性能问题解决
- EXT3文件系统修复
- 极验滑块验证码破解与研究(二):缺口图片还原
热门文章
- 题目:16版.雇员的工作职责(一)
- Spring MVC 测试 | 模拟提交表单
- linux下c 编译脚本,Linux下编译C语言与makefile脚本语言
- python读取图像数据流_浅谈TensorFlow中读取图像数据的三种方式
- 【转】如何开始学习CoreCLR源代码?
- Web Reference和Service Reference的区别
- VBA类之一(初识类)
- php记录登录时间,php记录 用户当前页面停留时间
- golang 包含 数组_Golang数组类型
- ios开发问题汇总(一)