四種情況
1、交叉鎖導致程式死鎖:例如執行緒A持有R1的鎖等待R2的鎖,執行緒B持有R2的鎖等待R1的鎖定
2、內存不足:例如兩個線程T1和T2,T1已獲取10MB內存,T2獲取了15MB內存,T1和T2都需要獲取30MB內存才能工作,但是剩餘可用的內存為10MB ,這樣兩個執行緒都在等待彼此釋放記憶體資源
3、一問一答式的資料交換:伺服器開啟某個端口,等待客戶端訪問,客戶端發送請求後,伺服器因某些原因錯過了客戶端請求,導致客戶端等待伺服器回應,而伺服器等待客戶端發送請求
4、死循環引起的死鎖:比較常見,使用jstack等工具看不到死鎖,但是程式不工作,CPU佔有率高,這種死鎖也叫系統假死,難以排查和重現
實例
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引發死鎖的情況有哪些的詳細內容。更多資訊請關注PHP中文網其他相關文章!