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

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
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值