Java线程死锁查看分析方法
日期: 2017-11-22 分类: 个人收藏 318次阅读
如何查看是否有Java线程死锁?下面介绍两种方法。
一.Jconsole
Jconsole是JDK自带的图形化界面工具,使用JDK给我们的的工具JConsole,可以通过打开cmd然后输入jconsole打开。
连接到需要查看的进程。
打开线程选项卡,然后点击左下角的“检测死锁” 。
jconsole就会给我们检测出该线程中造成死锁的线程,点击选中即可查看详情:
从上图中我们可以看出:
在线程Thread-1中,从状态可以看出,它想申请java.lang.Object@35b4e829这个资源,但是这个资源已经被Thread-0拥有了,所以就堵塞了。
在线程Thread-0中,从状态可以看出,它想申请java.lang.Object@2db8dc9这个资源,但是这个资源已经被Thread-1拥有了,所以就堵塞了。
Thread-1一直等待java.lang.Object@35b4e829资源,而Thread–0一直等待java.lang.Object@2db8dc9资源,于是这两个线程就这么僵持了下去,造成了死锁。
二.Jstack
Jstack是JDK自带的命令行工具,主要用于线程Dump分析。
1.我们先用Jps来查看java进程id(或者Linux的ps命令)
2.看一下jstack的使用
3.jstack输出线程dump信息到文件
用比较工程查看带-l和不带-l的区别如下:
4.查看dump文件,然后进行分析
其中有一行是at DeadThread.run(DeadThread.java:37),说明Thread-1实在DeadThread类的37行处发生死锁,其中at DeadThread.run(DeadThread.java:21),说明Thread-0是在DeadThread类的21行处发生死锁。详细的jstack dump文件分析请参看: 除特别声明,本站所有文章均为原创,如需转载请以超级链接形式注明出处:SmartCat's Blog
标签:1 开发
精华推荐