Java死锁检测的三种方法

方法一:jstack 进程号

首先使用jps查看Java进程编号,然后使用jstack查看进程信息,出现下述信息表示出现了死锁。jstack会在最后给出进程的分析信息,表示出现了死锁。
在这里插入图片描述
在这里插入图片描述

方法二:使用图形化工具jconsole.exe

第一步:打开jconsole,选择要检测的程序

在这里插入图片描述
在这里插入图片描述

第二步:点击检测死锁

在这里插入图片描述
检测死锁后,可以看到存在死锁的线程。
在这里插入图片描述

方法三:使用图形化工具jvisualvm.exe

第一步:选择程序,会自动检测死锁

在左侧选择要检测的Java程序,右侧会出现红色的字提醒:检测到死锁!。
在这里插入图片描述

第二步:查看堆栈信息

在这里插入图片描述
在这里插入图片描述
堆栈信息和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);
    }
}

在这里插入图片描述

  • 5
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值