在一个JVM进程中会存在有多个线程,但是一旦线程发生死锁,则很难进行问题的排查,所以在JDK中提供了一个jstack监控工具,该工具会对当前的Java虚拟机生成一个快照(每一个线程正在执行的方法堆栈集合),这样就可以帮助用户定位出长时间停顿线程所存在的问题(例如:死锁、死循环、资源等待),在使用时直接输入 jstack pid 命令即可。
下述代码在执行的时候会形成一个死锁:
class Book { } //描述图书的资源
class Paint { } //描述图画的资源
public class Demo {
public static void main(String[] args) throws Exception {
Book book = new Book(); //图书资源
Paint paint = new Paint(); //图画资源
Thread threadBook = new Thread(() -> {
synchronized (paint) { //锁定同步资源
System.out.println("张三对王八说:你借我你的书,我再借你我的画," +
"如果不先借我书我绝对不借你画。");
try { //设置休眠以便于死锁问题的显现
Thread.sleep(1000); //让程序问题乖乖露出水面
synchronized (book) {