一、死锁
死锁是指两个或两个以上进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力干涉它们都将无法推进下去。
二、死锁代码案例
package com.zhang;
import java.util.concurrent.TimeUnit;
public class HoldLockThreadTest {
public static void main(String[] args) {
//调用实现了Runnable接口的类
String lock001 = "lock001";
String lock002 = "lock002";
new Thread(new HoldLockThread(lock001,lock002),"001").start();
new Thread(new HoldLockThread(lock002,lock001),"002").start();
}
}
class HoldLockThread implements Runnable{
private String lock001;
private String lock002;
public HoldLockThread(String lock001,String locak002){
this.lock001 = lock001;
this.lock002 = locak002;
}
@Override
public void run() {
synchronized (lock001){
System.out.println("线程"+Thread.currentThread().getName()+"\t 自己持有锁"+lock001+"\t 尝试获取锁"+lock002);
try {//休眠5秒,为了演示死锁效果
TimeUnit.SECONDS.sleep(5);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock002){
System.out.println("线程"+Thread.currentThread().getName()+"\t 自己持有锁"+lock002+"\t 尝试获取锁"+lock001);
}
}
}
}
执行结果
可以看到IEDA执行结果一直未完成(控制台没有出现Process finished with code 0)
三、死锁的定位
利用快捷键ALT+F12打开IDEA控制台cmd窗口。
输入jps -l命令定位进程号
输入jstack 进程号找到死锁报告
利用jstack命令可以看到死锁已经发生了,即lock001和lock002互相死锁。