Java并發(fā)編程中的ReentrantLock詳解
Java ReentrantLock
從Java 5 開始,引入了一個(gè)高級(jí)的處理并發(fā)的java.util.concurrent包,它提供了大量更高級(jí)的并發(fā)功能,能大大簡化多線程程序的編寫。
我們知道Java語言直接提供了synchronized關(guān)鍵字用于加鎖,但是這種鎖一是很重,二是獲取時(shí)必須一直等待,沒有額外的嘗試機(jī)制。
java.util.concurrent.locks包提供了ReentrantLock用于替換synchronized加鎖,我們來看一下傳統(tǒng)的synchronized代碼:
public class Counter{ private int count; public void add(int n){ synchronized(this){ count += n; } } }
如果用ReentrantLock替代,可以把代碼改造為:
public class Counter{ private final Lock lock = new ReentrantLock(); private int count; public void add(int n){ lock.lock(); try{ count += n; }finally{ lock.unlock(); } } }
因?yàn)閟ynchronized是Java語言層面提供的語法,所以我們不需要考慮異常,而ReentrantLock是可重入鎖,它和synchronized一樣,一個(gè)線程可以多吃獲取同一個(gè)鎖。
和synchronized不同的是,ReentrantLock可以嘗試獲取鎖:
if(lock.tryLock(1,TimeUnit.SECONDS)){ try{ ... }finally{ lock.unlock(); } }
上述代碼在嘗試獲取鎖的時(shí)候,最多等待1秒
后仍未獲取到鎖,tryLock()返回false,程序就可以做一些額外處理的,而不是無限等待下去。
所以,使用ReentranLock比直接使用synchronized更安全,線程在tryLock()失敗的時(shí)候不會(huì)導(dǎo)致死鎖。
到此這篇關(guān)于Java并發(fā)編程中的ReentrantLock詳解的文章就介紹到這了,更多相關(guān)ReentrantLock詳解內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java Springboot websocket使用案例詳解
這篇文章主要介紹了Java Springboot websocket使用案例詳解,本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09Mybatis foreach用法解析--對(duì)于list和array
這篇文章主要介紹了Mybatis foreach用法解析--對(duì)于list和array,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03java如何實(shí)現(xiàn)判斷文件的真實(shí)類型
本篇文章主要介紹了java如何實(shí)現(xiàn)判斷文件的真實(shí)類型,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-08-08Java如何對(duì)方法進(jìn)行調(diào)用詳解
今天給大家整理了Java如何對(duì)方法進(jìn)行調(diào)用,文中有非常詳細(xì)的介紹及代碼示例,對(duì)正在學(xué)習(xí)java的小伙伴們很有幫助,需要的朋友可以參考下2021-06-06