淺談一下Java中的ReentrantLock
一、ReentrantLock是用來做什么的?
這個類是JUC工具包中對線程安全問題提供的一種解決方案,它主要是用來給對象上鎖,保證同一時間這能有一個線程在訪問當前對象。這樣處理是為了防止如果一個線程對某個公共變量進行了改變,而其它線程讀取時讀出來的是原有數(shù)據(jù)導致臟讀的問題。
二、ReentrantLock的實現(xiàn)原理是什么?
ReentrantLock主要是通過同步隊列和CAS機制來實現(xiàn)的,它實現(xiàn)的過程中主要包含下面幾個屬性:
- status:鎖狀態(tài),0表示沒有線程獲取鎖,1表示已有線程獲取鎖
- exclusiveOwnerThread:當前持有鎖的線程
- Node:節(jié)點,是ReentrantLock內(nèi)部維持的一個雙向鏈表(同步阻塞隊列)的基本構(gòu)成
具體流程
1、上鎖更新鎖狀態(tài):當A線程持有鎖時,會通過CAS將status狀態(tài)置為1,并將A線程自身存入exclusiveOwnerThread屬性當中;
2、線程入隊:而后線程B通過CAS獲取鎖時發(fā)現(xiàn)無法獲取鎖,此時就會獲取node信息,但是由于node雙向鏈表是null所以會通過CAS來創(chuàng)建一個雙向鏈表的head對象,之后再把線程B封裝成的Node節(jié)點通過尾插法接入雙向鏈表的尾部;
3、線程阻塞:入隊完成后再調(diào)用park方法進行阻塞;
4、釋放鎖并更新鎖狀態(tài):當A線程釋放鎖時會將status屬性重置為0,且把exclusiveOwnerThread置為null;
5、喚醒線程:A線程釋放鎖完畢后會調(diào)用unpark方法來喚醒雙向鏈表中下一節(jié)點的線程B;
三、ReentrantLock對比于Synchronized有哪些優(yōu)缺點?
1、ReentrantLock的鎖狀態(tài)是可見的,而Synchronized的鎖狀態(tài)是不可見的;
2、ReentrantLock是JDK層面的實現(xiàn),而Synchronized是JVM層面的實現(xiàn);
3、ReentrantLock需要手動釋放鎖,而Synchronized不需要手動釋放鎖;
4、ReentrantLock可以是非公平鎖也可以是公平鎖,而Synchronized只能是非公平鎖;
5、ReentrantLock是可被中斷的,而Synchronized是不可悲中斷的;
6、Synchronized在特定條件下是后來的線程先獲取鎖,而ReentrantLock是先來的線程先獲取鎖;
四、ReentrantLock的簡單使用
static ReentrantLock lock = new ReentrantLock();
for (int i = 0; i < 10; i++) {
Thread thread = new Thread(() -> {
lock.lock();
try {
for (int j = 0; j < 10000; j++) {
sum++;
}
} finally {
lock.unlock();
latch.countDown();
}
});
thread.start();
}到此這篇關于淺談一下Java中的ReentrantLock的文章就介紹到這了,更多相關淺談ReentrantLock內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
java數(shù)據(jù)結(jié)構(gòu)基礎:單,雙向鏈表
這篇文章主要介紹了Java的數(shù)據(jù)解構(gòu)基礎,希望對廣大的程序愛好者有所幫助,同時祝大家有一個好成績,需要的朋友可以參考下,希望能給你帶來幫助2021-07-07
解決mybatis-generator生成Mapper文件沒有Selective結(jié)尾的問題
這篇文章主要介紹了解決mybatis-generator生成Mapper文件沒有Selective結(jié)尾的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
Java窗體動態(tài)加載磁盤文件的實現(xiàn)方法
這篇文章主要介紹了Java窗體動態(tài)加載磁盤文件的實現(xiàn)方法,需要的朋友可以參考下2014-03-03
Spring + Mybatis 項目實現(xiàn)動態(tài)切換數(shù)據(jù)源實例詳解
這篇文章主要介紹了Spring + Mybatis 項目實現(xiàn)動態(tài)切換數(shù)據(jù)源的相關資料,需要的朋友參考下吧2017-04-04
Java語言之LinkedList和鏈表的實現(xiàn)方法
LinkedList是由傳統(tǒng)的鏈表數(shù)據(jù)結(jié)構(gòu)演變而來的,鏈表是一種基本的數(shù)據(jù)結(jié)構(gòu),它可以動態(tài)地增加或刪除元素,下面這篇文章主要給大家介紹了關于Java語言之LinkedList和鏈表的實現(xiàn)方法,需要的朋友可以參考下2023-05-05
http調(diào)用controller方法時openfeign執(zhí)行流程
這篇文章主要為大家介紹了http調(diào)用controller方法時openfeign執(zhí)行流程,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-07-07

