死锁排查

1.执行死锁代码

复制代码
public class DeadLockTest {
    public static void main(String[] args) throws InterruptedException {
        //a线程持有a锁,并尝试获取b锁;b线程持有b锁,并尝试获取a锁
        Object lockA = new Object();
        Object lockB = new Object();

        Thread threadA = new Thread(() -> {
            synchronized (lockA) {
                System.out.println("threadA获取到lockA,尝试获取lockB");
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (lockB) {
                    System.out.println("threadA获取到lockA,且获取到lockB");
                }
            }
        });

        Thread threadB = new Thread(() -> {
            synchronized (lockB) {
                System.out.println("threadB获取到lockB,尝试获取lockA");
                try {
                    Thread.sleep(2000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                synchronized (lockA) {
                    System.out.println("threadB获取到lockB,且获取到lockA");
                }
            }
        });

        threadA.start();
        threadB.start();

        threadA.join();
        threadB.join();
    }
}
复制代码

2.查看java进程:jsp -l 

 

 

 

 

 3.查看线程堆栈:jstack -l 96354

 

 

 最后明确说明发现了死锁

 

posted @   Katsu  阅读(17)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 25岁的心里话
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
点击右上角即可分享
微信分享提示