Java如何查看死锁?
轉載自?https://blog.csdn.net/u014039577/article/details/52351626
Java中當我們的開發涉及到多線程的時候,這個時候就很容易遇到死鎖問題,剛開始遇到死鎖問題的時候,我們很容易覺得莫名其妙,而且定位問題也很困難。
因為涉及到java多線程的時候,有的問題會特別復雜,而且就算我們知道問題出現是因為死鎖了,我們也很難弄清楚為什么發生死鎖,那么當我們遇到了死鎖問題,我們應該如何來檢測和查看死鎖呢?
Java中jdk 給我們提供了很便利的工具,幫助我們定位和分析死鎖問題:
1、死鎖產生原因:當兩個或者多個線程互相持有一定資源,并互相等待其他線程釋放資源而形成的一種僵局,就是死鎖。
2、構建一個死鎖的場景:
public class Test {public static void main(String[] args) {new Thread(new Runnable() {@Overridepublic void run() {synchronized (B.class) {try {Thread.sleep(1000);} catch (InterruptedException e) {e.printStackTrace();}synchronized (A.class) {}}}}).start();new Thread(new Runnable() {@Overridepublic void run() {synchronized (A.class) {try {Thread.sleep(1000);} catch (InterruptedException e) {// TODO Auto-generated catch blocke.printStackTrace();}synchronized (B.class) {}}}}).start();}} class A {}class B {}可以看到運行時,一個線程持有A資源,希望使用B資源,而另一個線程持有B資源,希望使用A?資源,然后就陷入了相互等待的僵局,這樣就形成了死鎖。
?
3、Jconsole查看死鎖
進入java安裝的位置,輸入Jconsole,然后彈出界面(或者進入安裝目錄/java/jdk1.70_80/bin/,點擊Jconsole.exe):
然后點擊進入:
然后點擊檢測死鎖:
然后可以看到造成死鎖的兩個線程,以及死鎖原因:
Thread-0:持有java.lang.Class@1694ce18,需要java.lang.Class@1feb0edd,但是java.lang.Class@1feb0edd卻被Thread-1持有,然后陷入等待。
Thread-1:持有java.lang.Class@1feb0edd,需要java.lang.Class@1694ce18,但是java.lang.Class@1694ce18卻被Thread-0持有,然后陷入等待。
4、Jstack查看死鎖:
同樣,也是進入jdk安裝目錄的bin下面,輸入jps,先查看我們要檢測死鎖的進程:
然后可以看到進程Test的進程號:8384,然后執行:Jstack -l 8384
查看死鎖信息:
總結
以上是生活随笔為你收集整理的Java如何查看死锁?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Java不同压缩算法的性能比较
- 下一篇: java幂等性的控制(技术论坛上整理成文