當一個資源被一個執行緒鎖定並且同時另一個執行緒需要該資源時,就會發生死鎖。此問題在多處理系統中經常發生。 當兩個或多個執行緒等待屬於另一個執行緒的資源時,可能會發生此問題。這是一個範例- 線程一 線程二 ##取得鎖定P取得鎖定Q tr> 請求鎖定Q請求鎖定P 線程一不會獲得鎖Q,因為它屬於到線程二。同樣,線程二也不會獲得鎖 P,因為它的原始所有者是線程一。 死鎖也可以是三向死鎖,如果三個執行緒和三個鎖是公共的,就會發生這種情況。同樣,四路、五路和其他死鎖也可能發生。 飢餓是多執行緒應用程式中一個或多個可運行執行緒的永久阻塞。