方法一:jstack 进程号
首先使用jps查看Java进程编号,然后使用jstack查看进程信息,出现下述信息表示出现了死锁。jstack会在最后给出进程的分析信息,表示出现了死锁。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/73821b9d05ea4c60837238eb44d3d456.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiN6KeB6ZW_5a6J6KeB5pmo6Zu-,size_20,color_FFFFFF,t_70,g_se,x_16#pic_left)
方法二:使用图形化工具jconsole.exe
第一步:打开jconsole,选择要检测的程序
![在这里插入图片描述](https://img-blog.csdnimg.cn/2c174d0081b942b9a63d030776f8836b.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiN6KeB6ZW_5a6J6KeB5pmo6Zu-,size_20,color_FFFFFF,t_70,g_se,x_16#pic_left)
第二步:点击检测死锁
检测死锁后,可以看到存在死锁的线程。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/7a2ee2500d464f5a8937b551d694d3ac.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiN6KeB6ZW_5a6J6KeB5pmo6Zu-,size_20,color_FFFFFF,t_70,g_se,x_16#pic_left)
方法三:使用图形化工具jvisualvm.exe
第一步:选择程序,会自动检测死锁
在左侧选择要检测的Java程序,右侧会出现红色的字提醒:检测到死锁!。 ![在这里插入图片描述](https://img-blog.csdnimg.cn/3b46c73760044f4897b3b6aad14c5a5f.png?x-oss-process=image/watermark,type_d3F5LXplbmhlaQ,shadow_50,text_Q1NETiBA5LiN6KeB6ZW_5a6J6KeB5pmo6Zu-,size_20,color_FFFFFF,t_70,g_se,x_16#pic_left)
第二步:查看堆栈信息
堆栈信息和jstack显示的差不多,堆栈信息中间部分比jstack多出一些信息。
附录:死锁代码
public class DeadLockTest{
public static void main(String[] args) throws InterruptedException {
Object lock1 = new Object();
Object lock2 = new Object();
new Thread() {
public void run() {
synchronized (lock1) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + "持有" + lock1 + ",尝试获取" + lock2);
synchronized (lock2) {
}
}
};
}.start();
new Thread() {
public void run() {
synchronized (lock2) {
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + "持有" + lock2 + ",尝试获取" + lock1);
synchronized (lock1) {
}
}
};
}.start();
Thread.sleep(1000);
}
}
![在这里插入图片描述](https://img-blog.csdnimg.cn/698d4e2220f545fd98dfbd31e4173e6a.png)
|