Java中ReentrantLock,公平锁,非公平锁与synchronized

本文内容及代码参考视频:https://www.bilibili.com/video/BV1ta4y1H73X/?spm_id_from=333.788.recommend_more_video.-1

ReentrantLock是Java开发中最常用到的组件之一,简单来说,可以把ReentrantLock理解为基于AQS所实现的公平锁与非公平锁,用于实现对共享资源对象的同步。它和synchronized关键字一样支持可重入,但在调度上相较于synchronized更加的灵活。接下来我们从其内部继承和功能实现上来对其进行详解。本文内容基于AQS的基础上讲解,如果对AQS不了解请先了解AQS的内容。

1.ReentrantLock的内部结构

ReentrantLock的源码定义如下:

public class ReentrantLock implements Lock, java.io.Serializable

我们可以看出,ReentrantLock是Lock接口的一个实现类,那它必然就会对Lock接口中定义的方法进行了实现,下面我们先看一下Lock接口中都定义了哪些方法:

public interface Lock {

    //尝试获取锁,如果锁被占有则等待获取
    void lock();

    //与lock类似,区别在于当前线程等待锁时,如果被中断,则直接抛出中断异常
    void lockInterruptibly() throws InterruptedException;

    //尝试获取锁,无论成功与否都直接返回
    boolean tryLock();
    //规定尝试获取所得时间
    boolean tryLock(long time, TimeUnit unit) throws InterruptedException;

    //解锁
    void unlock();
    //为当前lock绑定一个Condition对象
    Condition newCondition();
}

我们可以看出Lock接口中主要定义了加锁,解锁,锁中断和锁关联条件这几个方法,那么ReentrantLock中具体是怎么实现这些方法的呢?在了解这些具体的实现之前,我们不妨先来看一看ReentrantLock中都有哪些值的注意的内部属性:

 private final Sync sync;

其实ReentrantLock类内部只有一个内部属性,就是Sync类型的sync,它的初始化是在ReentrantLock初始化时候传入的,代码如下:

    public ReentrantLock() {
        sync = new NonfairSync();
    }

   
    public ReentrantLock(boolean fair) {
        sync = fair ? new FairSync() : new NonfairSync();
    }

我们可以看出ReentrantLock在初始化时,如果不传入值,会默认构造一个NonfairSync()实例赋值,而如果传入值则会根据传入值构造NonfairSync()或FairSync()实例,而

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值