데드락 현상 시연 및 해결
IDE 도구에서 다음 코드를 실행하여 종료되지 않음을 확인하고 DeadLockDemo
클래스를 클릭하고 마우스 오른쪽 단추를 클릭 한 open in Terminal
다음 콘솔을 엽니 다.
package thread;
import java.util.concurrent.TimeUnit;
public class DeadLockDemo {
public static void main(String[] args) {
String lockA = "lockA";
String lockB = "lockB";
new Thread(new HoldLockThread(lockA, lockB), "ThreadA").start();
new Thread(new HoldLockThread(lockB, lockA), "ThreadB").start();
}
}
class HoldLockThread implements Runnable {
private String lockA;
private String lockB;
public HoldLockThread(String lockA, String lockB) {
this.lockA = lockA;
this.lockB = lockB;
}
@Override
public void run() {
synchronized (lockA) {
System.out.println(Thread.currentThread().getName() + "\t自己持有:" + lockA + "\t尝试获取:" + lockB);
try {
TimeUnit.SECONDS.sleep(2);
} catch (Exception e) {
e.printStackTrace();
}
synchronized (lockB) {
System.out.println(Thread.currentThread().getName() + "\t自己持有:" + lockB + "\t尝试获取:" + lockA);
}
}
}
}
입력 상자 jps -l
, 스레드 목록보기, 입력 jstack 线程ID
.
jps -l
jstack 7104
이때 교착 상태가 발견되었습니다. Found 1 deadlock.
.