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)的更多相关文章

  1. java 可重入读写锁 ReentrantReadWriteLock 详解

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt206 读写锁 ReadWriteLock读写锁维护了一对相关的锁,一个用于只 ...

  2. 聊聊高并发(二十九)解析java.util.concurrent各个组件(十一) 再看看ReentrantReadWriteLock可重入读-写锁

    上一篇聊聊高并发(二十八)解析java.util.concurrent各个组件(十) 理解ReentrantReadWriteLock可重入读-写锁 讲了可重入读写锁的基本情况和基本的方法,显示了怎样 ...

  3. 聊聊高并发(二十八)解析java.util.concurrent各个组件(十) 理解ReentrantReadWriteLock可重入读-写锁

    这篇讲讲ReentrantReadWriteLock可重入读写锁,它不仅是读写锁的实现,而且支持可重入性. 聊聊高并发(十五)实现一个简单的读-写锁(共享-排他锁) 这篇讲了怎样模拟一个读写锁. 可重 ...

  4. 【java并发编程】ReentrantLock 可重入读写锁

    目录 一.ReentrantLock可重入锁 二.ReentrantReadWriteLock读写锁 三.读锁之间不互斥 欢迎关注我的博客,更多精品知识合集 一.ReentrantLock可重入锁 可 ...

  5. 018-并发编程-java.util.concurrent.locks之-ReentrantReadWriteLock可重入读写锁

    一.概述 ReentrantLock是一个排他锁,同一时间只允许一个线程访问,而ReentrantReadWriteLock允许多个读线程同时访问,但不允许写线程和读线程.写线程和写线程同时访问.相对 ...

  6. Java基础-Java中的并法库之线程池技术

    Java基础-Java中的并法库之线程池技术 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.什么是线程池技术 二.

  7. java基础---->java中正则表达式二

    跟正则表达式相关的类有:Pattern.Matcher和String.今天我们就开始Java中正则表达式的学习. Pattern和Matcher的理解 一.正则表达式的使用方法 一般推荐使用的方式如下 ...

  8. Java基础学习中一些词语和语句的使用

    在Java基础学习中,我们刚接触Java会遇到一些词和语句的使用不清的情况,不能很清楚的理解它的运行效果会是怎么样的,如:break,continue在程序中运行效果及跳转位置, 1.先来看看brea ...

  9. Java基础-Java中的堆内存和离堆内存机制

    Java基础-Java中的堆内存和离堆内存机制 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.

随机推荐

  1. Ubuntu16.04上用源代码安装ICE

    ubuntu16.04上用源代码安装ICE

  2. springboot打包成war后部署项目出现异常 LifecycleException: Failed to start component

    完整异常:org.apache.catalina.LifecycleException: Failed to start component [StandardEngine[Catalina].Sta ...

  3. JavaScript快速入门-ECMAScript本地对象(RexExp)

    一.概述 RegExp 对象表示正则表达式,它是对字符串执行模式匹配的强大工具. 正则表达式是由一个字符序列形成的搜索模式. 当你在文本中搜索数据时,你可以用搜索模式来描述你要查询的内容. 正则表达式 ...

  4. web项目_学生证管理系统

    项目简述: 基于java web实现学生卡管理系统,用户包括学生和学生处,分别实现以下功能. 学生: 1.对本人登录密码的修改 2.申请补办学生卡 3.查看学生卡补办状态 学生处: 1.对学生信息的管 ...

  5. 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 ...

  6. 公钥与私钥的理解,以及https的应用原理

    1.公钥与私钥原理1)鲍勃有两把钥匙,一把是公钥,另一把是私钥2)鲍勃把公钥送给他的朋友们----帕蒂.道格.苏珊----每人一把.3)苏珊要给鲍勃写一封保密的信.她写完后用鲍勃的公钥加密,就可以达到 ...

  7. PAT甲题题解-1042. Shuffling Machine (20)-模拟

    博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~http://www.cnblogs.com/chenxiwenruo/p/6789205.html特别不喜欢那些随便转载别人的原创文章又不给 ...

  8. PAT甲级题解-1097. Deduplication on a Linked List (25)-链表的删除操作

    给定一个链表,你需要删除那些绝对值相同的节点,对于每个绝对值K,仅保留第一个出现的节点.删除的节点会保留在另一条链表上.简单来说就是去重,去掉绝对值相同的那些.先输出删除后的链表,再输出删除了的链表. ...

  9. 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 ...

  10. 2-Twelfth Scrum Meeting20151212

    任务安排 成员 今日完成 明日任务 闫昊 获取视频播放的进度  获取视频播放进度 唐彬 解决handler可能引起的内存泄露问题  阅读IOS代码+阅读上届网络核心代码 史烨轩 下载service开发 ...