死锁排查的小窍门 --使用jdk自带管理工具jstack

时间:2021-09-17 14:54:15

本文版权归 远方的风lyh和博客园共有,欢迎转载,但须保留此段声明,并给出原文链接,谢谢合作。

开发时间久了,难免会写出一些一些死锁的代码,自己明明调用该方法可该方法就是不执行、不进该方法、日志也不打印!

这里我们模拟一段死锁的代码,使用jdk自带的管理工具来排查是不是死锁了!

 //死锁代码
public class DeadLockDemo implements Runnable{ public int flag = 1;
//静态对象是类的所有对象共享的
private static Object o1 = new Object(), o2 = new Object();
@Override
public void run() {
System.out.println("flag=" + flag);
if (flag == 1) {
synchronized (o1) {
try {
Thread.sleep(500); } catch (Exception e) {
e.printStackTrace();
}
synchronized (o2) {
System.out.println("1");
}
}
}
if (flag == 0) {
synchronized (o2) {
try {
Thread.sleep(500);
} catch (Exception e) {
e.printStackTrace();
}
synchronized (o1) {
System.out.println("0");
}
}
}
} public static void main(String[] args) { DeadLockDemo td1 = new DeadLockDemo();
DeadLockDemo td2 = new DeadLockDemo();
td1.flag = 1;
td2.flag = 0;
//td1,td2都处于可执行状态,但JVM线程调度先执行哪个线程是不确定的。
//td2的run()可能在td1的run()之前运行
new Thread(td1).start();
new Thread(td2).start(); }
}

启动该段代码,执行之后一直卡着

死锁排查的小窍门 --使用jdk自带管理工具jstack

接下来我们在终端使用指令 jps查询该类的端口号为7824

死锁排查的小窍门 --使用jdk自带管理工具jstack

再使用 jstack 端口号

jstack 

死锁排查的小窍门 --使用jdk自带管理工具jstack

可以发现该段程序死锁!