Java多线程之ReentrantLock

今天简单的分析一下ReentrantLock的源码,碍于水平有限,如有疏漏或者错误之处请指正。

JDK版本:jdk1.8.0_121

切入正题:

当我们使用它的时候一般都是这样new对象的:Lock lock = new ReentrantLock();那么先看一下ReentrantLock的构造函数。
	public ReentrantLock() {
	//当没有参数的时候,默认创建的是非公平锁。
        sync = new NonfairSync();
    }
	
	//当指定 fair这个是否公平参数时进行相应的创建。
	public ReentrantLock(boolean fair) {
        sync = fair ? new FairSync() : new NonfairSync();
    }

以上代码中出现了一个sync和两个new FairSync() ; new NonfairSync();对象,那么他们又分别是什么呢?

private final Sync sync;//它是ReentrantLock的私有对象引用

/*
*而Sync则是ReentrantLock内部的抽象类,它继承自*AbstractQueuedSynchronizer 
*/
abstract static class Sync extends AbstractQueuedSynchronizer {
	abstract void lock();
	....其他的不一一列举
}

**关于AbstractQueuedSynchronizer队列同步器,推荐文章:**http://www.jianshu.com/p/ac0fb814e1a3

而NonfairSync 和FairSync 则都是继承自上述抽象类Sync,他们同样是ReentrantLock的内部类

static final class NonfairSync extends Sync {
}

static final class FairSync extends Sync {
}

Synchorized区别

  • 可重入性
  • 锁的实现 显示锁基于JDK实现 synchorized是jvm实现
  • 性能区别 jdk6以后性能已经不存在太大区别,都是避免用户态进入内核阻塞状态

ReentrantLock独有的功能

  • 可以指定是否公平锁
  • 提供了Condition类,可以分组唤醒需要唤醒的线程
  • 提供中断等待锁的线程机制 lock.lockInterruptibly()
原文地址:https://www.cnblogs.com/Kevin-1992/p/12608418.html