您的位置:首页 > 编程语言 > Java开发

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、非共享锁(写锁)释放

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java-util-concurrent