在ReentrantLock中,调用lock()方法获取锁;调用unlock()方法释放锁。try-catch-finally执行操作放在try,抛出错误放在catch,解锁通常放在finally里面
ReentrantLock的实现依赖于Java同步器框架AbstractQueuedSynchronizer(本文简称之为AQS)。AQS使用一个整型的volatile变量(命名为state)来维护同步状态,马上我们会看到,这个volatile变量是ReentrantLock内存语义实现的关键。
ReentrantLock内部实现原理?ReentrantLock的acquire(),state(),release()三类方法作用(这三类方法有很多个不止三个)?
acquire用于加锁,state由volatile修饰表示当前锁的状态数,release用于释放锁(公平锁需要判断是否是顺序执行的线程,非公平锁不用判断是否是顺序执行的线程)
公平策略(FairSync)与非公平策略(NonfairSync):就绪队列的执行顺序是否是先到先执行,阻塞队列到就绪队列的顺序是否有先后,是的话就是公平,不是就是非公平(ReentrantLock的底层和操作系统的底层都是以非公平策略为主)