Java~使用JDK自带的工具来检测是否有死锁的现象

多线程的死锁

  • Java线程死锁是一个经典的多线程问题, 因为不同的线程都在等待根本不可能被释放的锁, 从而导致线程中的任务无法完成
  • 下面演示互相等待对方锁释放的死锁
/**
 * Created with IntelliJ IDEA.
 * Description: If you don't work hard, you will a loser.
 * User: Listen-Y.
 * Date: 2020-10-03
 * Time: 20:37
 */
public class DealThread implements Runnable {

    private String userName;

    public String getUserName() {
        return userName;
    }

    public void setUserName(String userName) {
        this.userName = userName;
    }

    //俩把锁
    private final Object lock1 = new Object();
    private final Object lock2 = new Object();


    @Override
    public void run() {

        if ("a".equals(userName)) {
            synchronized (lock1) {
                System.out.println("userName=" + userName + " :" + "进入lock1");
                try {
                    Thread.sleep(3000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

                synchronized (lock2) {
                    System.out.println("由lock1->进入->lock2");
                }
            }
        }

        if ("b".equals(userName)) {
            synchronized (lock2) {
                System.out.println("userName=" + userName + " :" + "进入lock2");
                try {
                    Thread.sleep(3000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }

                synchronized (lock1) {
                    System.out.println("由lock2->进入->lock1");
                }
            }
        }

    }
}

  • 启动类
/**
 * Created with IntelliJ IDEA.
 * Description: If you don't work hard, you will a loser.
 * User: Listen-Y.
 * Date: 2020-10-03
 * Time: 20:42
 */
public class Run {

    public static void main(String[] args) throws InterruptedException {
        DealThread dealThread = new DealThread();
        dealThread.setUserName("a");
        Thread thread = new Thread(dealThread);
        thread.start();
        //注意这里是等待0.1秒 而线程是等待三秒
        Thread.sleep(100);

        dealThread.setUserName("b");
        Thread thread1 = new Thread(dealThread);
        thread1.start();
    }

}

  • 运行结果
    在这里插入图片描述
  • 此时我们发现已经进入死锁

使用JDK检测死锁

  1. 在你安装JDK的bin目录下按住shift加鼠标右键启动powershell
  2. 输入jps命令
    在这里插入图片描述
  3. 知道我们启动类中死锁的线程的线程id是14784
  4. 使用jstack命令
    在这里插入图片描述
  5. 在最后面获得信息
    在这里插入图片描述
  • 浏览信息知道出现死锁的代码行在哪, 和在等待什么锁导致的死锁都可以发现.
  • 6
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值