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在进行资源的竞争,同时也输出了资源竞争代码所在行。

相关推荐
hsjkdhs6 小时前
C++之多态
开发语言·jvm·c++
AresXue7 小时前
Java字节码与流量回放
jvm
AresXue8 小时前
Java字节码改写之asm进阶使用
jvm
AresXue8 小时前
聊聊为什么java会有这么多的字节码改写方式(jdk/cglib/asm/javasist)?
jvm
程序员卷卷狗13 小时前
JVM实战:从内存模型到性能调优的全链路剖析
java·jvm·后端·性能优化·架构
晓风残月淡16 小时前
JVM字节码与类的加载(一):类的加载过程详解
开发语言·jvm·python
lpruoyu2 天前
颜群JVM【05】强软弱虚引用
jvm
勤奋菲菲2 天前
使用Mybatis-Plus,以及sqlite的使用
jvm·sqlite·mybatis
稚辉君.MCA_P8_Java2 天前
JVM第二课:一文讲透运行时数据区
jvm·数据库·后端·容器
杨DaB2 天前
【JavaSE】JVM
java·jvm