java.util.concurrent包图文源码解析(三)——ReentrantReadWriteLock

来源:互联网 发布:查中药的软件 编辑:程序博客网 时间:2024/06/07 21:48
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、非共享锁(写锁)释放
这里写图片描述

阅读全文
0 0
原创粉丝点击