/**
* @ClassName Lock
* @Description 可重入锁
* @Author Administrator
* @Date 2019/6/8 16:58
* @Version 1.0
**/
public class Lock{
boolean isLocked = false;
Thread lockedBy = null;
int lockedCount = 0;
/**
* 可重入就意味着:线程可以进入任何一个它已经拥有的锁所同步着的代码块
* @throws InterruptedException
*/
/**
* 我们设计两个线程调用print()方法,第一个线程调用print()方法获取锁,进入lock()方法,
* 由于初始lockedBy是null,所以不会进入while而挂起当前线程,
* 而是是增量lockedCount并记录lockBy为第一个线程。接着第一个线程进入doAdd()方法,
* 由于同一进程,所以不会进入while而挂起,接着增量lockedCount,
* 当第二个线程尝试lock,由于isLocked=true,所以他不会获取该锁,
* 直到第一个线程调用两次unlock()将lockCount递减为0,才将标记为isLocked设置为false
* @throws InterruptedException
*/
public synchronized void lock() throws InterruptedException{
Thread thread = Thread.currentThread();
while(isLocked && lockedBy != thread){
wait();
}
isLocked = true;
lockedCount++;
lockedBy = thread;
}
public synchronized void unlock(){
if(Thread.currentThread() == this.lockedBy){
lockedCount--;
if(lockedCount == 0){
isLocked = false;
notify();
}
}
}
}
原文:https://www.cnblogs.com/wylwyl/p/10991193.html