本文小編為大家詳細介紹“java中引發(fā)死鎖的情況是什么”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當(dāng),希望這篇“java中引發(fā)死鎖的情況是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學(xué)習(xí)新知識吧。
成都創(chuàng)新互聯(lián)專注于企業(yè)營銷型網(wǎng)站建設(shè)、網(wǎng)站重做改版、冠縣網(wǎng)站定制設(shè)計、自適應(yīng)品牌網(wǎng)站建設(shè)、H5場景定制、商城網(wǎng)站制作、集團公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁設(shè)計等建站業(yè)務(wù),價格優(yōu)惠性價比高,為冠縣等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
java引發(fā)死鎖的4種情況
1、交叉鎖引發(fā)程序死鎖:比如線程A持有R1的鎖等待R2的鎖,線程B持有R2的鎖等待R1的鎖。
2、內(nèi)存不足:比如兩個線程T1和T2,T1已獲取10MB內(nèi)存,T2獲取了15MB內(nèi)存,T1和T2都需要獲取30MB內(nèi)存才能工作,但是剩余可用的內(nèi)存為10MB,這樣兩個線程都在等待彼此釋放內(nèi)存資源。
3、一問一答式的數(shù)據(jù)交換:服務(wù)器開啟某個端口,等待客戶端訪問,客戶端發(fā)送請求后,服務(wù)器因某些原因錯過了客戶端請求,導(dǎo)致客戶端等待服務(wù)器回應(yīng),而服務(wù)器等待客戶端發(fā)送請求。
4、死循環(huán)引起的死鎖:比較常見,使用jstack等工具看不到死鎖,但是程序不工作,CPU占有率高,這種死鎖也叫系統(tǒng)假死,難以排查和重現(xiàn)。
死鎖相關(guān)實例
public class Main { private final Object MUTEX_READ = new Object(); private final Object MUTEX_WRITE = new Object(); public void read(){ synchronized (MUTEX_READ){ synchronized (MUTEX_WRITE){ } } } public void write(){ synchronized (MUTEX_WRITE){ synchronized (MUTEX_READ){ } } } public static void main(String[] args) throws InterruptedException { Main m = new Main(); new Thread(()->{ while (true){ m.read(); } }).start(); new Thread(()->{ while (true){ m.write(); } }).start(); } }
讀到這里,這篇“java中引發(fā)死鎖的情況是什么”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領(lǐng)會,如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。