java并发可重入锁ReentrantLock非公平锁

说明:

       

/**
     * Creates an instance of {@code ReentrantLock}.
     * This is equivalent to using {@code ReentrantLock(false)}.
     */
    public ReentrantLock() {
        sync = new NonfairSync();
    }

    /**
     * Creates an instance of {@code ReentrantLock} with the
     * given fairness policy.
     *
     * @param fair {@code true} if this lock should use a fair ordering policy
     */
    public ReentrantLock(boolean fair) {
        sync = fair ? new FairSync() : new NonfairSync();
    }

ReentrantLock默认是非公平锁,如果要创建一个公平锁,则实例化锁时需要传递参数fair,为true

说一下非公平锁的逻辑:

可以先参考一下ReentrantLock公平锁的逻辑

当线程1释放锁时,如果是公平锁,则当有线程3来临时,会先判断一下等待队列是否为空,如果不为空,则把自己加入到等待队列的末尾,如果等待队列为空,则尝试加锁,加锁失败加入等待队列,加锁成功则执行自己的业务逻辑

如果是非公平锁,当线程1释放线程,线程1会唤醒等待队列中的线程2,而此时线程3来临,它不会判断等待队列是否为空,会直接尝试加锁,由于线程1释放了锁,state=0, 加锁线程=null, 线程3尝试CAS加锁,加锁成功,state=1, 加锁线程=线程3。线程2被唤醒之后去尝试CAS加锁,而现在的锁被线程3获取,则会再次加锁失败,会进入等待队列继续等待

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值