JVM优化之使用Jstack命令查找JVM死锁

JVM优化之使用Jstack命令查找JVM死锁

示例代码

java 复制代码
public class DeadLockDemo {

    private static Object lock1 = new Object();
    private static Object lock2 = new Object();

    public static void main(String[] args) {
        new Thread(() -> {
            synchronized (lock1) {
                try {
                    System.out.println("thread1 begin");
                    Thread.sleep(5000);
                } catch (InterruptedException e) {
                }
                synchronized (lock2) {
                    System.out.println("thread1 end");
                }
            }
        }).start();

        new Thread(() -> {
            synchronized (lock2) {
                try {
                    System.out.println("thread2 begin");
                    Thread.sleep(5000);
                } catch (InterruptedException e) {
                }
                synchronized (lock1) {
                    System.out.println("thread2 end");
                }
            }
        }).start();
    }
}

使用下面的命令输出线程信息

java 复制代码
jstack <pid>

"Thread-1" 线程名

prio=5 优先级=5

tid=0x0000028ae51d6000 线程id

nid=0x8778 线程对应的本地线程标识nid

java.lang.Thread.State: BLOCKED 线程状态

通过输出结果,可以看到有一个线程死锁,Thread-0和Thread-1在进行资源的竞争,同时也输出了资源竞争代码所在行。

相关推荐
她说..32 分钟前
Java 基本数据类型高频面试题
java·开发语言·jvm·spring boot
明灯伴古佛2 小时前
面试:什么是可重入性?为什么 synchronized 是可重入锁?
java·jvm·面试
PrDf22Iw84 小时前
编译执行与解释执行的区别是什么?JVM 使用哪种方式?
jvm
!停5 小时前
C++入门—内存管理
java·jvm·c++
Engineer邓祥浩6 小时前
JVM学习笔记(5) 第二部分 自动内存管理 第4章 虚拟机性能监控、故障处理工具
jvm·笔记·学习
woai33646 小时前
JVM学习-基础篇-垃圾回收
java·jvm·学习
aP8PfmxS27 小时前
Lab3-page tables && MIT6.1810操作系统工程【持续更新】
java·linux·jvm
Derrick__11 天前
Android混淆和加密技术
android·jvm·python
LSL666_1 天前
JVM——OOM异常
jvm
minji...1 天前
Linux 多线程(一)线程概念,轻量级进程,执行流,线程创建
java·开发语言·jvm