本文目錄一覽:
如何使用java的鎖機制
多線程同步的實現最終依賴鎖機制。我們可以想像某一共享資源是一間屋子,每個人都是一個線程。當a希望進入房間時,他必須獲得門鎖,一旦a獲得門鎖,他進去後就立刻將門鎖上,於是b,c,d…就不得不在門外等待,直到a釋放鎖出來後,b,c,d…中的某一人搶到了該鎖(具體搶法依賴於jvm的實現,可以先到先得,也可以隨機挑選),然後進屋又將門鎖上。這樣,任一時刻最多有一人在屋內(使用共享資源)。
java語言規範內置了對多線程的支持。對於java程序來說,每一個對象實例都有一把「鎖」,一旦某個線程獲得了該鎖,別的線程如果希望獲得該鎖,只能等待這個線程釋放鎖之後。獲得鎖的方法只有一個,就是synchronized關鍵字。
java中的鎖有哪幾種
lock比synchronized比較如下:
1) 支持公平鎖,某些場景下需要獲得鎖的時間與申請鎖的時間相一致,但是synchronized做不到
2) 支持中斷處理,就是說那些持有鎖的線程一直不釋放,正在等待的線程可以放棄等待。如果不支持中斷處理,那麼線程可能一直無限制的等待下去,就算那些正在佔用資源的線程死鎖了,正在等待的那些資源還是會繼續等待,但是ReentrantLock可以選擇放棄等待
3) condition和lock配合使用,以獲得最大的性能
JAVA中鎖使用的幾點建議:
1.如果沒有特殊的需求,建議使用synchronized,因為操作簡單,便捷,不需要額外進行鎖的釋放。鑒於JDK1.8中的ConcurrentHashMap也使用了CAS+synchronized的方式替換了老版本中使用分段鎖(ReentrantLock)的方式,可以得知,JVM中對synchronized的性能做了比較好的優化。
2.如果代碼中有特殊的需求,建議使用Lock。例如並發量比較高,且有些操作比較耗時,則可以使用支持中斷的所獲取方式;如果對於鎖的獲取,講究先來後到的順序則可以使用公平鎖;另外對於多個變數的鎖保護可以通過lock中提供的condition對象來和lock配合使用,獲取最大的性能。
在java中有哪些鎖
給你整理了Java中的一些鎖:
公平鎖/非公平鎖
可重入鎖
獨享鎖/共享鎖
互斥鎖/讀寫鎖
樂觀鎖/悲觀鎖
分段鎖
偏向鎖/輕量級鎖/重量級鎖
自旋鎖
上面是很多鎖的名詞,這些分類並不是全是指鎖的狀態,有的指鎖的特性,有的指鎖的設計
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/285153.html