Java 執行緒的死鎖問題
阿新 • • 發佈:2018-12-18
Java 執行緒的死鎖問題
1.死鎖
不同的執行緒分別佔用對方需要的同步資源不放棄,都在等待對方放棄自己需要的同步資源,就形成了執行緒的死鎖
2.解決方法
- 專門的演算法、原則
① 比較出名的演算法有(銀行家演算法、鴕鳥演算法)
② 破壞死鎖產生條件 - 儘量減少同步資源的定義
- 後續補充避免死鎖其他相關的內容。
3.產生死鎖的一個demo
//死鎖的問題:處理執行緒同步的時候,容易出現 public class TestDeadLock { static StringBuffer sb1 = new StringBuffer(); static StringBuffer sb2 = new StringBuffer(); public static void main(String[] args) { new Thread() { public void run() { synchronized(sb1) { try { Thread.currentThread().sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } sb1.append("A"); synchronized(sb2) { sb2.append("B"); System.out.println(sb1); System.out.println(sb2); } } } }.start(); new Thread() { public void run() { synchronized(sb2) { try { Thread.currentThread().sleep(10); } catch (InterruptedException e) { e.printStackTrace(); } sb1.append("C"); synchronized(sb1) { sb2.append("D"); System.out.println(sb1); System.out.println(sb2); } } } }.start(); } }