java.util.concurrent包图文源码解析(三)——ReentrantReadWriteLock
2017-07-16 10:40
846 查看
ReentrantReadWriteLock 可读写,公平非公平都占了。 还是温习一下继承关系:
看下公平和非公平的实现:
内部类Sync实现了自己的特性,读写是不是需要阻塞,以此实现公平和非公平的锁争夺。
锁获取
1、共享锁(读锁)获取再总结一下: 1、如果有线程持有写锁且该线程不是当前线程,直接返回-1 ,就是说自己线程可以同时读写,但是别人写,自己读会出现线程不安全的情况。 2、没有线程持有写锁,或者就是当前线程。那么再判断在公平非公平逻辑中返回readerShouldBlock,那么就阻塞,但是阻塞之前也有判断 2.1 如果是第一个读取的,不管;意思就是只能一个人读 2.2 不是第一个读取的,但是自己已经读取过了,再次读取不管 3、读取不需要阻塞 3.1、自己是第一个加锁的人,做出优化,用firstReader和firstReaderHoldCount 3.2、读锁重入,自己线程专属的变量firstReaderHoldCount++ 3.3 r!=0(有人持有读锁)&&不是第一个持有读锁的线程,从ThreadLocal中取出变量rh.count++;
2、非共享锁(写锁)获取
锁释放
1、共享锁(读锁)释放2、非共享锁(写锁)释放
相关文章推荐
- jdk源码解读-并发包-Lock-ReentrantReadWriteLock(1)-整体介绍以及读锁的lock 和 unlock 解析
- 【JUC源码解析】ReentrantReadWriteLock
- ReentrantReadWriteLock 读写锁获取与释放源码解析
- ReentrantReadWriteLock源码解析
- java.util.concurrent.locks.ReentrantReadWriteLock读写锁源码解析
- java.util.concurrent包图文源码解析(二)——ReentrantLock
- jdk 源码分析(9)java ReentrantReadWriteLock分析
- Lock、ReentrantLock、ReentrantReadWriteLock原理及应用深入解析
- Concurrent包源码解读之ReentrantLock,ReentrantReadWriteLock
- JUC之ReentrantReadWriteLock(JDK1.8源码)
- 从源码来看ReentrantLock和ReentrantReadWriteLock
- 从源码来看ReentrantLock和ReentrantReadWriteLock
- 聊聊高并发(二十九)解析java.util.concurrent各个组件(十一) 再看看ReentrantReadWriteLock可重入读-写锁
- 聊聊高并发(二十九)解析java.util.concurrent各个组件(十一) 再看看ReentrantReadWriteLock可重入读-写锁
- JUC源码分析13-locks-ReentrantReadWriteLock
- 聊聊高并发(二十八)解析java.util.concurrent各个组件(十) 理解ReentrantReadWriteLock可重入读-写锁
- JUC - ReentrantReadWriteLock 源码分析
- J.U.C并发框架源码阅读(十七)ReentrantReadWriteLock
- ReentrantReadWriteLock实现分析(源码)
- 【Java8源码分析】locks包-ReentrantReadWriteLock