java - lock與synchronize的解鎖順序問題?
問題描述
在學(xué)習(xí)lock與synchronize的區(qū)別時(shí),看到這樣一句話:“ lock更靈活,可以自由定義多把鎖的枷鎖解鎖順序(synchronized要按照先加的后解順序)”。請(qǐng)問這里:
1.lock的自由定義多把鎖的枷鎖解鎖順序怎么理解?2.synchronized要按照先加的后解順序怎么理解?
謝謝各位!
問題解答
回答1:Lock是一個(gè)接口,最常用的實(shí)現(xiàn)是 ReentrantLock,它的一個(gè)靈活之處是可以設(shè)定fair參數(shù)。
synchronized 和fair=false的ReentrantLock 無法決定加鎖順序。換句話說,線程A、B、C都要鎖定對(duì)象,嘗試鎖定的時(shí)間是A最早、然后是B,最后是C,那么當(dāng)A解鎖對(duì)象時(shí),不能確定到底B還是C接下來鎖定對(duì)象。
如果用fair=true的ReentrantLock(公平鎖),情況就確定了:A解鎖對(duì)象時(shí),由于B比C先嘗試鎖定對(duì)象,所以接下來一定是B來鎖定,只有當(dāng)B解鎖時(shí)才輪到C。
回答2:new lock1new lock2lock1.lock();lock2.lock();...lock2.unlock();lock1.unlock();
Lock的加解鎖是在java語義層面上實(shí)現(xiàn)的,鎖之間沒有必然關(guān)系
synchronized(obj1){ synchronized(obj2){... }}
synchronized加解鎖是由JVM來實(shí)現(xiàn),在執(zhí)行完synchronized塊后自行解鎖,所有會(huì)按照synchronized的嵌套順序解鎖。
相關(guān)文章:
1. javascript - node.js promise沒用2. golang - 用IDE看docker源碼時(shí)的小問題3. c++ - 如何正確的使用QWebEngineView?4. yii2中restful配置好后在nginx下報(bào)404錯(cuò)誤5. javascript - js 寫一個(gè)正則 提取文本中的數(shù)據(jù)6. 算法 - python 給定一個(gè)正整數(shù)a和一個(gè)包含任意個(gè)正整數(shù)的 列表 b,求所有<=a 的加法組合7. android 如何實(shí)現(xiàn)如圖中的鍵盤上的公式及edittext的內(nèi)容展示呢8. java - 我在用Struts2上傳文件時(shí),報(bào)以下錯(cuò)誤怎么回事?9. 請(qǐng)問是對(duì)象還是數(shù)組10. thinkphp6使用驗(yàn)證器 信息如何輸出到前端頁面
