并发编程--锁--如何使用命令行和代码定位死锁

Posted liaowenhui

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了并发编程--锁--如何使用命令行和代码定位死锁相关的知识,希望对你有一定的参考价值。

用命令行的方式找到死锁

本地环境下,如果程序发生死锁后,首先cmd进入${JAVA_HOME}/bin/中,输入jps命令,就可以查看到当前 Java 程序的 pid,找到死锁类的pid后执行jstack命令+空格+死锁类的 pid,就可以获取线程获取锁的信息。

技术图片

截取一部分和死锁相关的有用信息

技术图片

常见命令解析

(1)jps(Java Virtual Machine Process Status Tool),是java提供的一个显示当前所有java进程pid的命令,适合在linux/unix平台上简单察看当前java进程的一些简单情况。

其中PID相当于内存给它(进程)分配的名字,每个进程都有属于自己唯一的一个PID,我们可以利用找到PID来处理相应的进程,上图中27824就是pid。

技术图片

2)jstack主要用来查看某个Java进程内的线程堆栈信息.

用代码来定位死锁的方式

使用ThreadMXBean 工具类

技术图片

技术图片

运行结果

技术图片

 

以上是关于并发编程--锁--如何使用命令行和代码定位死锁的主要内容,如果未能解决你的问题,请参考以下文章

Java并发编程实战读书笔记之死锁

Java并发编程实战读书笔记之死锁

Java并发编程实战之互斥锁

Java并发编程实战之互斥锁

Python——并发编程02

Java并发编程-各种锁