首先来解释一下什么叫做可重入锁;
可重入锁就是可以重入的锁;比如有一个线程访问一个类中的普通方法时;获取到了临界资源,持有锁;那么在执行该方法中时,其内层调用方法也需要获取同样的锁;那么内层方法就会自动获取锁;
举一个例子:
synchronized void setA () throws Exception{
Thread.sleep(1000);
setB();
}
synchronized void setB () throws Exception{
Thread.sleep(1000);
}
线程抢到了锁去执行方法A;在方法A中又调用了方法B;由于B方法是在A中被调用的,并且该线程持有执行A方法所需要的锁;因此在执行方法B的时候就自动获取锁;去执行方法B;
可重入锁可以避免线程死锁也可以从上述举例代码中看出来;
假如Synchronized不是可重入锁;那么该线程获取到执行A方法所需要的锁之后开始执行A方法;但是在执行过程中遇到了方法B;由于是不可重入锁;B方法也是被Synchronized关键字修饰;所以执行B方法也需要获取锁;但是此时A方法代码还未执行完成,继续占有锁;B方法就获取不到锁,被阻塞;A方法迟迟执行不完成,所以也就一直不释放锁;因此;就产生了死锁
synchronized和ReentrantLock都是可重入锁;当然Reentrant还可以设置成为公平性锁,也就是不可重入锁;synchronized只是可重入锁,也就是不公平的锁
那么不可重入锁就很容易理解啦
所谓不可重入锁,即若当前线程执行某个方法已经获取了该锁,那么在方法中尝试再次获取锁时,就会获取不到被阻塞。