Java基础-Java中的并法库之重入读写锁(ReentrantReadWriteLock)
Java基础-Java中的并法库之重入读写锁(ReentrantReadWriteLock)
作者:尹正杰
版权声明:原创作品,谢绝转载!否则将追究法律责任。
在学习Java的之前,你可能已经听说过读锁,写锁,读写锁,乐观锁,悲观锁。这些名词在学习数据库的时候几乎每个人都会有所了解的!当你学习java网络编程时,尤其是在处理多并发的情况时,你可能用过“synchronized”关键字是同步的方法,它可以用来同步代码块也可以用来同步方法。但JAVA中的锁并不是只有“synchronized”哟,在Java的并发库中你可能会进程看到一些可重入所(ReentrantLock)。
本篇博客就以重入读写锁(ReentrantReadWriteLock)来测试当两个线程的读锁和写锁是否可用同时访问。
一.两个线程同时上读锁的情况
1>.测试代码如下:
/*
@author :yinzhengjie
Blog:http://www.cnblogs.com/yinzhengjie/tag/Java%E5%9F%BA%E7%A1%80/
EMAIL:y1053419035@qq.com
*/
package cn.org.yinzhengjie.nio; import java.util.concurrent.locks.ReentrantReadWriteLock; /**
* 重入锁测试
*/
public class ReentrantLockDemo {
public static void main(String[] args) {
//通过并法库包的ReentrantReadWriteLock获取读写锁,里面既包含读锁也包含写锁。
final ReentrantReadWriteLock lock = new ReentrantReadWriteLock() ; //开启2个线程,看他们谁先抢到线程谁就会先打印数据。最好是通过IDE的调试方法查看他们的执行过程。
new Thread(){
public void run() {
//上读锁
lock.readLock().lock();
System.out.println("xxx");
//解读锁
lock.readLock().unlock();
}
}.start(); new Thread(){
public void run() {
//上读锁
lock.readLock().lock();
System.out.println("yyy");
//上读锁
lock.readLock().unlock();
}
}.start();
}
}
2>.IDEA打断点注意事项

3>.运行Debug模式并进入第一个线程

4>.查看控制台输出信息

5>.运行线程2的代码

6>.查看线程2的控制台

7>.得出结论
答:在同一个程序中,一个线程拿到读锁且未释放锁时,另一个线程仍然可以继续使用读锁,他们之间并不互相影响!
二.两个线程一个上读锁,一个上写锁的情况
1>.测试代码
/*
@author :yinzhengjie
Blog:http://www.cnblogs.com/yinzhengjie/tag/Java%E5%9F%BA%E7%A1%80/
EMAIL:y1053419035@qq.com
*/
package cn.org.yinzhengjie.nio; import java.util.concurrent.locks.ReentrantReadWriteLock; /**
* 重入锁测试
*/
public class ReentrantLockDemo {
public static void main(String[] args) {
//通过并法库包的ReentrantReadWriteLock获取读写锁,里面既包含读锁也包含写锁。
final ReentrantReadWriteLock lock = new ReentrantReadWriteLock() ; //开启2个线程,看他们谁先抢到线程谁就会先打印数据。最好是通过IDE的调试方法查看他们的执行过程。
new Thread(){
public void run() {
//上读锁
lock.readLock().lock();
System.out.println("xxx");
//解读锁
lock.readLock().unlock();
}
}.start(); new Thread(){
public void run() {
//上写锁
lock.writeLock().lock();
System.out.println("yyy");
//解写锁
lock.writeLock().unlock();
}
}.start();
}
}
2>.执行第一个线程

3>.查看控制端是有内容输出的

4>.切换到第二个线程执行代码

5>.得出结论
答:当一个线程拿到读锁时,另一个线程无法使用写锁!
三.两个线程一个上写锁,一个上读锁的情况
1>.测试代码
/*
@author :yinzhengjie
Blog:http://www.cnblogs.com/yinzhengjie/tag/Java%E5%9F%BA%E7%A1%80/
EMAIL:y1053419035@qq.com
*/
package cn.org.yinzhengjie.nio; import java.util.concurrent.locks.ReentrantReadWriteLock; /**
* 重入锁测试
*/
public class ReentrantLockDemo {
public static void main(String[] args) {
//通过并法库包的ReentrantReadWriteLock获取读写锁,里面既包含读锁也包含写锁。
final ReentrantReadWriteLock lock = new ReentrantReadWriteLock() ; //开启2个线程,看他们谁先抢到线程谁就会先打印数据。最好是通过IDE的调试方法查看他们的执行过程。
new Thread(){
public void run() {
//上读锁
lock.writeLock().lock();
System.out.println("xxx");
//解读锁
lock.writeLock().unlock();
}
}.start(); new Thread(){
public void run() {
//上写锁
lock.readLock().lock();
System.out.println("yyy");
//解写锁
lock.readLock().unlock();
}
}.start();
}
}
2>.执行第一个线程

3>.查看第一个线程输出的内容

4>.执行第二线程

5>.得出结论
答:当一个线程拿到写锁时,另一个线程无法使用读锁!
四.两个线程同时上写锁的情况
1>.测试代码
/*
@author :yinzhengjie
Blog:http://www.cnblogs.com/yinzhengjie/tag/Java%E5%9F%BA%E7%A1%80/
EMAIL:y1053419035@qq.com
*/
package cn.org.yinzhengjie.nio; import java.util.concurrent.locks.ReentrantReadWriteLock; /**
* 重入锁测试
*/
public class ReentrantLockDemo {
public static void main(String[] args) {
//通过并法库包的ReentrantReadWriteLock获取读写锁,里面既包含读锁也包含写锁。
final ReentrantReadWriteLock lock = new ReentrantReadWriteLock() ; //开启2个线程,看他们谁先抢到线程谁就会先打印数据。最好是通过IDE的调试方法查看他们的执行过程。
new Thread(){
public void run() {
//上读锁
lock.writeLock().lock();
System.out.println("xxx");
//解读锁
lock.writeLock().unlock();
}
}.start(); new Thread(){
public void run() {
//上写锁
lock.writeLock().lock();
System.out.println("yyy");
//解写锁
lock.writeLock().unlock();
}
}.start();
}
}
2>.执行第一个线程

3>.查看第一个线程输出的内容

4>.执行第二线程

5>.得出结论
答:当一个线程拿到写锁时,另一个线程无法使用写锁!
Java基础-Java中的并法库之重入读写锁(ReentrantReadWriteLock)的更多相关文章
- java 可重入读写锁 ReentrantReadWriteLock 详解
详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt206 读写锁 ReadWriteLock读写锁维护了一对相关的锁,一个用于只 ...
- 聊聊高并发(二十九)解析java.util.concurrent各个组件(十一) 再看看ReentrantReadWriteLock可重入读-写锁
上一篇聊聊高并发(二十八)解析java.util.concurrent各个组件(十) 理解ReentrantReadWriteLock可重入读-写锁 讲了可重入读写锁的基本情况和基本的方法,显示了怎样 ...
- 聊聊高并发(二十八)解析java.util.concurrent各个组件(十) 理解ReentrantReadWriteLock可重入读-写锁
这篇讲讲ReentrantReadWriteLock可重入读写锁,它不仅是读写锁的实现,而且支持可重入性. 聊聊高并发(十五)实现一个简单的读-写锁(共享-排他锁) 这篇讲了怎样模拟一个读写锁. 可重 ...
- 【java并发编程】ReentrantLock 可重入读写锁
目录 一.ReentrantLock可重入锁 二.ReentrantReadWriteLock读写锁 三.读锁之间不互斥 欢迎关注我的博客,更多精品知识合集 一.ReentrantLock可重入锁 可 ...
- 018-并发编程-java.util.concurrent.locks之-ReentrantReadWriteLock可重入读写锁
一.概述 ReentrantLock是一个排他锁,同一时间只允许一个线程访问,而ReentrantReadWriteLock允许多个读线程同时访问,但不允许写线程和读线程.写线程和写线程同时访问.相对 ...
- Java基础-Java中的并法库之线程池技术
Java基础-Java中的并法库之线程池技术 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是线程池技术 二.
- java基础---->java中正则表达式二
跟正则表达式相关的类有:Pattern.Matcher和String.今天我们就开始Java中正则表达式的学习. Pattern和Matcher的理解 一.正则表达式的使用方法 一般推荐使用的方式如下 ...
- Java基础学习中一些词语和语句的使用
在Java基础学习中,我们刚接触Java会遇到一些词和语句的使用不清的情况,不能很清楚的理解它的运行效果会是怎么样的,如:break,continue在程序中运行效果及跳转位置, 1.先来看看brea ...
- Java基础-Java中的堆内存和离堆内存机制
Java基础-Java中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.
随机推荐
- Ubuntu16.04上用源代码安装ICE
ubuntu16.04上用源代码安装ICE
- springboot打包成war后部署项目出现异常 LifecycleException: Failed to start component
完整异常:org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].Sta ...
- JavaScript快速入门-ECMAScript本地对象(RexExp)
一.概述 RegExp 对象表示正则表达式,它是对字符串执行模式匹配的强大工具. 正则表达式是由一个字符序列形成的搜索模式. 当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容. 正则表达式 ...
- web项目_学生证管理系统
项目简述: 基于java web实现学生卡管理系统,用户包括学生和学生处,分别实现以下功能. 学生: 1.对本人登录密码的修改 2.申请补办学生卡 3.查看学生卡补办状态 学生处: 1.对学生信息的管 ...
- git 报错 error: insufficient permission for adding an object to repository database ./objects
参照:http://stackoverflow.com/questions/1918524/error-pushing-to-github-insufficient-permission-for-ad ...
- 公钥与私钥的理解,以及https的应用原理
1.公钥与私钥原理1)鲍勃有两把钥匙,一把是公钥,另一把是私钥2)鲍勃把公钥送给他的朋友们----帕蒂.道格.苏珊----每人一把.3)苏珊要给鲍勃写一封保密的信.她写完后用鲍勃的公钥加密,就可以达到 ...
- PAT甲题题解-1042. Shuffling Machine (20)-模拟
博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6789205.html特别不喜欢那些随便转载别人的原创文章又不给 ...
- PAT甲级题解-1097. Deduplication on a Linked List (25)-链表的删除操作
给定一个链表,你需要删除那些绝对值相同的节点,对于每个绝对值K,仅保留第一个出现的节点.删除的节点会保留在另一条链表上.简单来说就是去重,去掉绝对值相同的那些.先输出删除后的链表,再输出删除了的链表. ...
- LeetCode 70. Climbing Stairs爬楼梯 (C++)
题目: You are climbing a stair case. It takes n steps to reach to the top. Each time you can either cl ...
- 2-Twelfth Scrum Meeting20151212
任务安排 成员 今日完成 明日任务 闫昊 获取视频播放的进度 获取视频播放进度 唐彬 解决handler可能引起的内存泄露问题 阅读IOS代码+阅读上届网络核心代码 史烨轩 下载service开发 ...