Java如何查看死锁?
轉(zhuǎn)載自?https://blog.csdn.net/u014039577/article/details/52351626
Java中當(dāng)我們的開(kāi)發(fā)涉及到多線程的時(shí)候,這個(gè)時(shí)候就很容易遇到死鎖問(wèn)題,剛開(kāi)始遇到死鎖問(wèn)題的時(shí)候,我們很容易覺(jué)得莫名其妙,而且定位問(wèn)題也很困難。
因?yàn)樯婕暗絡(luò)ava多線程的時(shí)候,有的問(wèn)題會(huì)特別復(fù)雜,而且就算我們知道問(wèn)題出現(xiàn)是因?yàn)樗梨i了,我們也很難弄清楚為什么發(fā)生死鎖,那么當(dāng)我們遇到了死鎖問(wèn)題,我們應(yīng)該如何來(lái)檢測(cè)和查看死鎖呢?
Java中jdk 給我們提供了很便利的工具,幫助我們定位和分析死鎖問(wèn)題:
1、死鎖產(chǎn)生原因:當(dāng)兩個(gè)或者多個(gè)線程互相持有一定資源,并互相等待其他線程釋放資源而形成的一種僵局,就是死鎖。
2、構(gòu)建一個(gè)死鎖的場(chǎng)景:
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 {}可以看到運(yùn)行時(shí),一個(gè)線程持有A資源,希望使用B資源,而另一個(gè)線程持有B資源,希望使用A?資源,然后就陷入了相互等待的僵局,這樣就形成了死鎖。
?
3、Jconsole查看死鎖
進(jìn)入java安裝的位置,輸入Jconsole,然后彈出界面(或者進(jìn)入安裝目錄/java/jdk1.70_80/bin/,點(diǎn)擊Jconsole.exe):
然后點(diǎn)擊進(jìn)入:
然后點(diǎn)擊檢測(cè)死鎖:
然后可以看到造成死鎖的兩個(gè)線程,以及死鎖原因:
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查看死鎖:
同樣,也是進(jìn)入jdk安裝目錄的bin下面,輸入jps,先查看我們要檢測(cè)死鎖的進(jìn)程:
然后可以看到進(jìn)程Test的進(jìn)程號(hào):8384,然后執(zhí)行:Jstack -l 8384
查看死鎖信息:
總結(jié)
以上是生活随笔為你收集整理的Java如何查看死锁?的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: Java不同压缩算法的性能比较
- 下一篇: Java Fork/Join 框架