您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“java中引發(fā)死鎖的情況是什么”,內(nèi)容詳細,步驟清晰,細節(jié)處理妥當,希望這篇“java中引發(fā)死鎖的情況是什么”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
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ù)交換:服務器開啟某個端口,等待客戶端訪問,客戶端發(fā)送請求后,服務器因某些原因錯過了客戶端請求,導致客戶端等待服務器回應,而服務器等待客戶端發(fā)送請求。
4、死循環(huán)引起的死鎖:比較常見,使用jstack等工具看不到死鎖,但是程序不工作,CPU占有率高,這種死鎖也叫系統(tǒng)假死,難以排查和重現(xià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)介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內(nèi)容的文章,歡迎關注億速云行業(yè)資訊頻道。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。