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