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

   日期:2020-10-05     浏览:103    评论:0    
核心提示:文章目录多线程的死锁使用JDK检测死锁多线程的死锁Java线程死锁是一个经典的多线程问题, 因为不同的线程都在等待根本不可能被释放的锁, 从而导致线程中的任务无法完成下面演示互相等待对方锁释放的死锁

文章目录

    • 多线程的死锁
    • 使用JDK检测死锁

多线程的死锁

  • Java线程死锁是一个经典的多线程问题, 因为不同的线程都在等待根本不可能被释放的锁, 从而导致线程中的任务无法完成
  • 下面演示互相等待对方锁释放的死锁

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");
                }
            }
        }

    }
}

  • 启动类

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. 在最后面获得信息
  • 浏览信息知道出现死锁的代码行在哪, 和在等待什么锁导致的死锁都可以发现.
 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服