1、自旋鎖定
自旋鎖定顧名思義,它會等待一定時間(自旋),在這期中會什麼都不做就是等資源被釋放,好處在於沒有了內核態用戶態切換的效率損失,但是如果它一直不能訪問到資源的話就會一直佔用cpu資源,所以它會循環一段時間後進入阻塞狀態。
2、重量級鎖定
synchronized就是重量級鎖定的實作機制,搶不到資源的進程就會進入阻塞狀態。
3、偏向鎖定
顧名思義,它會偏向第一個存取資源的進程,如果說只有一個進程執行同步程式碼區塊,那麼就會上個偏向鎖,如果有其他執行緒搶佔資源,那麼就會升級為輕量級鎖。
4、輕量級鎖定
偏向鎖定升級之後就是輕量級鎖定,鎖定只可以升級而不可以降級。輕量級鎖定中的其他程序會進入自選狀態,如果說自選失敗,就會升級會重量級鎖定。
5、公平、非公正鎖
主要是指線程是否先來後到拿到鎖,synchronized是非公平的,而ReentrantLock預設為非公平,可以設定為公平鎖。
6、悲觀鎖定
總是假設最壞的情況,每次去拿資料的時候都認為別人會修改,所以每次在拿資料的時候都會上鎖,這樣別人想拿這個資料就會阻塞直到它拿到鎖(共享資源每次只給一個執行緒使用,其它執行緒阻塞,用完後再把資源轉讓給其它執行緒)。
傳統的關係型資料庫裡邊就用到了很多這種鎖機制,例如行鎖,表鎖等,讀鎖,寫鎖等,都是在做操作之前先上鎖。 Java中synchronized和ReentrantLock等獨佔鎖就是悲觀鎖思想的實現。
7、樂觀鎖
總是假設最好的情況,每次去拿資料的時候都認為別人不會修改,所以不會上鎖,但在更新的時候會判斷一下在這段期間別人有沒有去更新這個數據,可以使用版本號機制(資料庫中)和CAS演算法實作。
推薦教學:Java教學
以上是Java中常見的幾種鎖的詳細內容。更多資訊請關注PHP中文網其他相關文章!