ReentrantLock—>可重入锁
- ReentranLock类实现了Lock,它拥有与synchronized相同的并发性和内存语义,在现实线程安全的控制中,比较常用的是ReentrantLock,可以显示加锁,释放锁。
实现Lock锁
public class TestLock {
public static void main(String[] args) {
TestLock2 testLock2 = new TestLock2();
new Thread(testLock2).start();
new Thread(testLock2).start();
new Thread(testLock2).start();
}
}
class TestLock2 implements Runnable{
int ticketNums = 10;
private final ReentrantLock lock = new ReentrantLock();
@Override
public void run() {
while (true){
try {
lock.lock();//加锁
if (ticketNums>0){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(ticketNums--);
}else {
break;
}
}finally{
lock.unlock();//解锁
}
}
}
}
需要将有异常的代码放在try{}里面,最后通过lock.unlock来解锁
- Lock是显式锁(手动开启和关闭,别忘记关闭锁)synchronized是隐式锁,出了作用域自动释放
- Lock只有代码锁,synchronized有代码块和方法锁
- 使用Lock,JVM将花费较少的时间来调度线程,性能跟好。并且具有更好的扩展性(提供更多的子类)
- 优先使用顺序:
- Lock>同步代码块(已经进入了方法体,分配了相应资源)>同步方法(在方法体之外)



