Java死鎖代碼實例及產生死鎖必備的四個條件
更新時間:2024年01月16日 09:50:39 作者:加油當當
這篇文章主要介紹了Java死鎖代碼實例及產生死鎖必備的四個條件,Java 發(fā)生死鎖的根本原因是,在申請鎖時發(fā)生了交叉閉環(huán)申請,synchronized在開發(fā)中最好不要嵌套使用,容易導致死鎖,需要的朋友可以參考下
Java死鎖
- Java 發(fā)生死鎖的根本原因是:在申請鎖時發(fā)生了交叉閉環(huán)申請;
- 據(jù)說面試喜歡考;
- synchronized在開發(fā)中最好不要嵌套使用,容易導致死鎖;
public class DeadLock {
public static void main(String[] args) {
Object o1 = new Object();
Object o2 = new Object();
// t1和t2兩個線程共享o1,o2
Thread t1 = new MyThread1(o1,o2);
Thread t2 = new MyThread2(o1,o2);
t1.start();
t2.start();
}
}
class MyThread1 extends Thread{
Object o1;
Object o2;
public MyThread1(Object o1,Object o2){
this.o1 = o1;
this.o2 = o2;
}
public void run(){
synchronized (o1){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (o2){
}
}
}
}
class MyThread2 extends Thread {
Object o1;
Object o2;
public MyThread2(Object o1,Object o2){
this.o1 = o1;
this.o2 = o2;
}
public void run(){
synchronized (o2){
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (o1){
}
}
}
}產生死鎖必須具備以下四個條件:【必會】
- 互斥條件:該資源任意一個時刻只由一個線程占用;
- 請求與保持條件:一個進程因請求資源而阻塞時,對已獲得的資源保持不放;
- 不剝奪條件:線程已獲得的資源在未使用完之前不能被其他線程強行剝奪,只有自己使用完畢后才釋放資源;
- 循環(huán)等待條件:若干進程之間形成一種頭尾相接的循環(huán)等待資源關系;(比如一個進程集合,A在等B,B在等C,C在等A);
到此這篇關于Java死鎖代碼實例及產生死鎖必備的四個條件的文章就介紹到這了,更多相關Java死鎖內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Apache Dubbo的SPI機制是如何實現(xiàn)的
SPI全稱為Service Provider Interface,對應中文為服務發(fā)現(xiàn)機制。SPI類似一種可插拔機制,首先需要定義一個接口或一個約定,然后不同的場景可以對其進行實現(xiàn),調用方在使用的時候無需過多關注具體的實現(xiàn)細節(jié)。在Java中,SPI體現(xiàn)了面向接口編程的思想,滿足開閉設計原則。2021-06-06
Kotlin + Spring Boot 請求參數(shù)驗證的代碼實例
本篇文章主要介紹了Kotlin + Spring Boot 請求參數(shù)驗證的代碼實例,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
SSH框架網上商城項目第4戰(zhàn)之EasyUI菜單的實現(xiàn)
SSH框架網上商城項目第4戰(zhàn)之EasyUI菜單的實現(xiàn),本文主要使用EasyUI技術簡單實現(xiàn)后臺菜單,感興趣的小伙伴們可以參考一下2016-05-05
如何實現(xiàn)nohup?java進程號一直在變方法步驟詳解
這篇文章主要為大家介紹了如何實現(xiàn)nohup?java進程號一直在變方法步驟詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-11-11

