java - lock與synchronize的解鎖順序問題?
問題描述
在學(xué)習(xí)lock與synchronize的區(qū)別時,看到這樣一句話:“ lock更靈活,可以自由定義多把鎖的枷鎖解鎖順序(synchronized要按照先加的后解順序)”。請問這里:
1.lock的自由定義多把鎖的枷鎖解鎖順序怎么理解?2.synchronized要按照先加的后解順序怎么理解?
謝謝各位!
問題解答
回答1:Lock是一個接口,最常用的實現(xiàn)是 ReentrantLock,它的一個靈活之處是可以設(shè)定fair參數(shù)。
synchronized 和fair=false的ReentrantLock 無法決定加鎖順序。換句話說,線程A、B、C都要鎖定對象,嘗試鎖定的時間是A最早、然后是B,最后是C,那么當(dāng)A解鎖對象時,不能確定到底B還是C接下來鎖定對象。
如果用fair=true的ReentrantLock(公平鎖),情況就確定了:A解鎖對象時,由于B比C先嘗試鎖定對象,所以接下來一定是B來鎖定,只有當(dāng)B解鎖時才輪到C。
回答2:new lock1new lock2lock1.lock();lock2.lock();...lock2.unlock();lock1.unlock();
Lock的加解鎖是在java語義層面上實現(xiàn)的,鎖之間沒有必然關(guān)系
synchronized(obj1){ synchronized(obj2){... }}
synchronized加解鎖是由JVM來實現(xiàn),在執(zhí)行完synchronized塊后自行解鎖,所有會按照synchronized的嵌套順序解鎖。
相關(guān)文章:
1. Python從URL中提取域名2. 實現(xiàn)bing搜索工具urlAPI提交3. 數(shù)據(jù)庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。4. python - scrapy url去重5. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)6. 關(guān)于mysql聯(lián)合查詢一對多的顯示結(jié)果問題7. python執(zhí)行cmd命令,怎么讓他執(zhí)行類似Ctrl+C效果將其結(jié)束命令?8. node.js - 微信小程序websocket連接問題9. node.js - windows10下的npm全局路徑的復(fù)原或者將npm徹底刪除?10. python - Django有哪些成功項目?
