java - lock與synchronize的解鎖順序問題?
問題描述
在學習lock與synchronize的區別時,看到這樣一句話:“ lock更靈活,可以自由定義多把鎖的枷鎖解鎖順序(synchronized要按照先加的后解順序)”。請問這里:
1.lock的自由定義多把鎖的枷鎖解鎖順序怎么理解?2.synchronized要按照先加的后解順序怎么理解?
謝謝各位!
問題解答
回答1:Lock是一個接口,最常用的實現是 ReentrantLock,它的一個靈活之處是可以設定fair參數。
synchronized 和fair=false的ReentrantLock 無法決定加鎖順序。換句話說,線程A、B、C都要鎖定對象,嘗試鎖定的時間是A最早、然后是B,最后是C,那么當A解鎖對象時,不能確定到底B還是C接下來鎖定對象。
如果用fair=true的ReentrantLock(公平鎖),情況就確定了:A解鎖對象時,由于B比C先嘗試鎖定對象,所以接下來一定是B來鎖定,只有當B解鎖時才輪到C。
回答2:new lock1new lock2lock1.lock();lock2.lock();...lock2.unlock();lock1.unlock();
Lock的加解鎖是在java語義層面上實現的,鎖之間沒有必然關系
synchronized(obj1){ synchronized(obj2){... }}
synchronized加解鎖是由JVM來實現,在執行完synchronized塊后自行解鎖,所有會按照synchronized的嵌套順序解鎖。
相關文章:
1. android - NavigationView 的側滑菜單中如何保存新增項(通過程序添加)2. php7.3.4中怎么開啟pdo驅動3. python-mysqldb - 這樣結構的mysql表,如何快速update4. 提示語法錯誤語法錯誤: unexpected ’abstract’ (T_ABSTRACT)5. 編程學習心得分享(共80條)6. 這段代碼既不提示錯誤也看不到結果,請老師明示錯在哪里,謝謝!7. 老師 我是一個沒有學過php語言的準畢業生 我希望您能幫我一下8. ueditor上傳服務器提示后端配置項沒有正常加載,求助!!!!!9. mysql - select查詢多個紀錄的條件怎么寫10. tp5 不同控制器中的變量調用問題
