java 中死鎖問題的實例詳解
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),必然死鎖,下面來做說明。
這個僅僅是為了理解死鎖和面試用的,創(chuàng)建兩個對象a和b只是為了作為死鎖的對象而用,線程t1運行(t1.start()),線程t1拿到鎖a后,需要繼續(xù)執(zhí)行,拿到鎖b,而線程t2運行(t2.start()),拿到鎖b,想繼續(xù)拿到鎖a繼續(xù)執(zhí)行,這就形成死鎖,互相持有對面所需要的鎖對象。
如果面試,可以簡單記下,兩個線程,兩個鎖對象,鎖互相嵌套,最少兩種狀態(tài),同時執(zhí)行,一次不行就多次,也可鎖外面加循環(huán),讓線程多次運行,就會死鎖,因為運行一次,可能存在偶然,第一個線程執(zhí)行完了,鎖對象釋放了,第二個線程才進來執(zhí)行,如此就有偶然現(xiàn)象。
如有疑問請留言或者到本站社區(qū)交流討論,感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
GitLab+Jenkins+Maven+Tomcat?實現(xiàn)自動集成、打包、部署
本文主要介紹了GitLab?+?Jenkins?+?Maven?+?Tomcat?實現(xiàn)自動集成、打包、部署,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01Spring boot實現(xiàn)上傳文件到本地服務(wù)器
這篇文章主要為大家詳細介紹了Spring boot實現(xiàn)上傳文件到本地服務(wù)器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-08-08springboot結(jié)合前端實現(xiàn)網(wǎng)頁跳轉(zhuǎn)功能實例
今天處理Springboot統(tǒng)一異常攔截的時候,遇到了頁面跳轉(zhuǎn)的問題,這篇文章主要給大家介紹了關(guān)于springboot結(jié)合前端實現(xiàn)網(wǎng)頁跳轉(zhuǎn)功能的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下2023-12-12分享Java8中通過Stream對列表進行去重的實現(xiàn)
本文主要介紹了分享Java8中通過Stream對列表進行去重的實現(xiàn),包括兩種方法,具有一定的參考價值,感興趣的可以了解一下2023-11-11