Lock
和Synchronized
都是java去用來解決執行緒安全問題的一個工具
Synchronized
是java中的同步關鍵字,Lock是J.U.C包中提供的接口,而這個接口有很多的實現類,包括ReentrantLock這樣重入鎖的實現,Synchronized可以透過兩種方式去控制鎖的力度
# 一種把synchronized
關鍵字修飾在方法層面,另一種是修飾在程式碼區塊上,可以透過synchronized
加鎖物件的生命週期,來控制鎖的作用範圍,鎖定物件是靜態物件或是類別對象,那麼這個鎖定就是屬於全域鎖,如果鎖定對象就是普通實例對象,那麼這個鎖的範圍取決於這個實例的生命週期,Lock中鎖的粒度是透過它裡面提供的lock()方法和unlock()
方法來決定的
如上圖:在lock()方法和unlock()
方法之間的程式碼,是能夠確保執行緒安全的,而鎖的作用域取決於Lock實例的生命週期。 Lock比Synchronized
的彈性更高,Lock可以自主的去決定什麼時候加鎖,什麼時候釋放鎖,只需要呼叫lock()和unlock這兩個方法就可以了,Lock還提供了非阻塞的競爭鎖的方法,叫做tryLock()
,這個方法可以透過傳回true/false來告訴目前執行緒是否已經有其他執行緒正在使用鎖,而Synchronized由於是關鍵字,所以它無法去實現非阻塞競爭鎖的方法,Synchroized
鎖的釋放是被動的,當Synchronized同步程式碼區塊,執行結束以後,或者程式碼出現異常的時候才會被釋放,Lock提供了公平鎖和非公平鎖的機制,公平鎖是指線程競爭鎖資源的時候,已經有其它線程正在排隊,或者等待鎖釋放,那麼當前競爭鎖的線程,是無法去插隊的,非公平鎖就是不管是否有線程在排隊等待鎖,它都會去嘗試去競爭一次鎖,Synchronized只提供方了一種非公平鎖的實作。
Synchronized
和lock在效能方面相差不大,在實作上會有一定的差別,Synchronized
引入了偏向鎖,輕量級鎖,重量級鎖以及鎖升級的機制來實現鎖的優化,而Lock中則用到了自旋鎖的方式去實現性能優化
以上是Java中Lock和Synchronized的差別是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!