淺談Java中Lock和Synchronized的區(qū)別
1. 從功能角度來看
Lock
和Synchronized
都是java中去用來解決線程安全問題的一個工具
2. 從特性來看
Synchronized
是java中的同步關鍵字,Lock是J.U.C
包中提供的接口,而這個接口有很多的實現(xiàn)類,包括ReentrantLock
這樣重入鎖的實現(xiàn),Synchronized
可以通過兩種方式去控制鎖的力度
一種把synchronized
關鍵字修飾在方法層面,另一種是修飾在代碼塊上,可以通過synchronized
加鎖對象的生命周期,來控制鎖的作用范圍,鎖對象是靜態(tài)對象或者是類對象,那么這個鎖就是屬于全局鎖,如果鎖對象是普通實例對象,那么這個鎖的范圍取決于這個實例的生命周期,Lock中鎖的粒度是通過它里面提供的lock()
方法和unlock()
方法來決定的
如上圖:在lock()方法和unlock()
方法之間的代碼,是能夠保證線程安全的,而鎖的作用域 取決于Lock實例的生命周期。Lock比Synchronized
的靈活性更高,Lock可以自主的去決定什么時候加鎖,什么時候釋放鎖,只需要調(diào)用lock()
和unlock
這兩個方法就可以了,Lock還提供了非阻塞的競爭鎖的方法,叫tryLock()
,這個方法可以通過返回true/false
來告訴當前線程是否已經(jīng)有其他線程正在使用鎖,而Synchronized由于是關鍵字,所以它無法去實現(xiàn)非阻塞競爭鎖的方法,Synchroized
鎖的釋放是被動的,當Synchronized
同步代碼塊,執(zhí)行結(jié)束以后,或者代碼出現(xiàn)異常的時候才會被釋放,Lock提供了公平鎖和非公平鎖的機制,公平鎖是指線程競爭鎖資源的時候,已經(jīng)有其它線程正在排隊,或者等待鎖釋放,那么當前競爭鎖的線程,是無法去插隊的,非公平鎖就是不管是否有線程在排隊等待鎖,它都會去嘗試去競爭一次鎖,Synchronized
只提供方了一種非公平鎖的實現(xiàn)。
3. 從性能方面來看
Synchronized
和lock在性能方面相差不大,在實現(xiàn)上會有一定的區(qū)別,Synchronized
引入了偏向鎖,輕量級鎖,重量級鎖以及鎖升級的機制來實現(xiàn)鎖的優(yōu)化,而Lock中則用到了自旋鎖的方式去實現(xiàn)性能優(yōu)化
到此這篇關于淺談Java中Lock
和Synchronized
的區(qū)別的文章就介紹到這了,更多相關Lock
和Synchronized
的區(qū)別內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
深度優(yōu)先與廣度優(yōu)先Java實現(xiàn)代碼示例
這篇文章主要介紹了深度優(yōu)先與廣度優(yōu)先Java實現(xiàn)代碼示例,具有一定借鑒價值,需要的朋友可以參考下。2017-12-12mybatis-plus IdWorker生成的Id和返回給前臺的不一致的解決
這篇文章主要介紹了mybatis-plus IdWorker生成的Id和返回給前臺的不一致的解決,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-03-03解析使用jdbc,hibernate處理clob/blob字段的詳解
本篇是對使用jdbc,hibernate處理clob/blob字段進行了詳細的分析介紹,需要的朋友參考下2013-05-05Java使用正則表達式實現(xiàn)找出數(shù)字功能示例
這篇文章主要介紹了Java使用正則表達式實現(xiàn)找出數(shù)字功能,結(jié)合實例形式分析了Java針對數(shù)字的匹配查找及非數(shù)字替換操作相關實現(xiàn)技巧,需要的朋友可以參考下2017-03-03