java 中死鎖問題的實例詳解
先看代碼在做解釋
public class DeadLock implements Runnable{
String a;
String b;
boolean flag;
public DeadLock(String a,String b,boolean flag){
this.a=a;
this.b=b;
this.flag=flag;
}
public void run(){
if(flag){
// while(true){
synchronized(a){
System.out.println("鎖a");
synchronized(b){
System.out.println("鎖b----");
}
}
// }
}else{
// while(true){
synchronized(b){
System.out.println("鎖b");
synchronized(a){
System.out.println("鎖a----");
}
}
// }
}
}
public static void main(String[] args){
String a=new String("a");
String b=new String("b");
DeadLock d1=new DeadLock(a,b,true);
DeadLock d2=new DeadLock(a,b,false);
Thread t1=new Thread(d1);
Thread t2=new Thread(d2);
t1.start();
t2.start();
System.out.println("歡聲笑語中打出GG");
}
}
以上是代碼部分,如果沒有死鎖,可以在if下加while(true),必然死鎖,下面來做說明。
這個僅僅是為了理解死鎖和面試用的,創建兩個對象a和b只是為了作為死鎖的對象而用,線程t1運行(t1.start()),線程t1拿到鎖a后,需要繼續執行,拿到鎖b,而線程t2運行(t2.start()),拿到鎖b,想繼續拿到鎖a繼續執行,這就形成死鎖,互相持有對面所需要的鎖對象。
如果面試,可以簡單記下,兩個線程,兩個鎖對象,鎖互相嵌套,最少兩種狀態,同時執行,一次不行就多次,也可鎖外面加循環,讓線程多次運行,就會死鎖,因為運行一次,可能存在偶然,第一個線程執行完了,鎖對象釋放了,第二個線程才進來執行,如此就有偶然現象。
如有疑問請留言或者到本站社區交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。