摘要:在包中有很多的實(shí)現(xiàn)類,常用的有,其實(shí)現(xiàn)都依賴類,實(shí)現(xiàn)思路都大同小異。類調(diào)用,進(jìn)而調(diào)用類讓操作系統(tǒng)進(jìn)行和,從而達(dá)到線程的阻塞和恢復(fù)。
在java.util.concurrent.locks包中有很多Lock的實(shí)現(xiàn)類,常用的有ReentrantLock、ReentrantReadWriteLock,其實(shí)現(xiàn)都依賴java.util.concurrent.AbstractQueuedSynchronizer類,實(shí)現(xiàn)思路都大同小異。
同時(shí),Lock提供了Condition接口,類似與Object的wait/notify,但比后者要方便的多、靈活的多。
ReentrantLock的調(diào)用過程ReentrantLock把所有Lock接口的操作都委派到一個(gè)Sync類上,該類繼承了AbstractQueuedSynchronizer。
static abstract class Sync extends AbstractQueuedSynchronizer
Sync又有兩個(gè)子類:
final static class NonfairSync extends Sync final static class FairSync extends Sync
Reentrant.lock()方法的調(diào)用過程(默認(rèn)非公平鎖):
AbstractQueuedSynchronizer通過構(gòu)造一個(gè)基于阻塞的CLH隊(duì)列容納所有的阻塞線程,而對(duì)該隊(duì)列的操作均通過Lock-Free(CAS)操作,但對(duì)已經(jīng)獲得鎖的線程而言,ReentrantLock實(shí)現(xiàn)了偏向鎖的功能。
非公平鎖的代碼中總是優(yōu)先嘗試當(dāng)前是否有線程持有鎖,一旦沒有任何線程持有鎖,那么非公平鎖就霸道的嘗試將鎖“占為己有”。如果在搶占鎖的時(shí)候失敗就和公平鎖一樣老老實(shí)實(shí)的去請(qǐng)求。也即是說公平鎖和非公平鎖只是在入AQS的CLH隊(duì)列之前有所差別,一旦進(jìn)入了隊(duì)列,所有線程都是按照隊(duì)列中先來后到的順序請(qǐng)求鎖。
Lock類調(diào)用LockSupport,LockSupport進(jìn)而調(diào)用Unsafe類讓操作系統(tǒng)進(jìn)行park和unpack,從而達(dá)到線程的阻塞和恢復(fù)。
ReentrantReadWriteLock類適用于有很多線程都從某個(gè)數(shù)據(jù)結(jié)構(gòu)中讀取數(shù)據(jù)而很少有線程對(duì)其進(jìn)行修改的場(chǎng)景,允許讀取器線程共享訪問,但與寫入器線程依然是互斥的。
private ReentrantReadWriteLock rwl = new ReentrantReadWriteLock(); private Lock readLock = rwl.readLock(); //得到一個(gè)可被多個(gè)讀操作共用的讀鎖,但它會(huì)排斥所有寫操作 private Lock writeLock = rwl.writeLock(); //得到一個(gè)寫鎖,它會(huì)排斥所有其他的讀操作和寫操作 public double getTotalBalance(){ readLock.lock(); try { ... } finally { readLock.unlock(); } } public void transfer(){ writeLock.lock(); try { ... } finally { writeLock.unlock(); } }
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/67031.html
摘要:整個(gè)包,按照功能可以大致劃分如下鎖框架原子類框架同步器框架集合框架執(zhí)行器框架本系列將按上述順序分析,分析所基于的源碼為。后,根據(jù)一系列常見的多線程設(shè)計(jì)模式,設(shè)計(jì)了并發(fā)包,其中包下提供了一系列基礎(chǔ)的鎖工具,用以對(duì)等進(jìn)行補(bǔ)充增強(qiáng)。 showImg(https://segmentfault.com/img/remote/1460000016012623); 本文首發(fā)于一世流云專欄:https...
摘要:用于生成虛擬機(jī)當(dāng)前時(shí)刻的線程快照。線程快照就是當(dāng)前虛擬機(jī)內(nèi)每一條線程正在執(zhí)行的方法堆棧的集合,生成線程快照的主要目的就是定位線程出現(xiàn)長(zhǎng)時(shí)間停頓的原因,如線程死鎖死循環(huán)請(qǐng)求外部資源導(dǎo)致的長(zhǎng)時(shí)間等待等都是導(dǎo)致線程長(zhǎng)時(shí)間停頓的常見原因。 在JDK的命令行中,一般開發(fā)人員最耳熟能詳?shù)目隙ň褪莏ava,javac,javap等常用命令,不過在jdk/bin下還有許多其他的命令行工具,它們被用來監(jiān)...
Lock對(duì)象 同步代碼依賴于簡(jiǎn)單的可重入鎖,這種鎖易于使用,但有許多限制,java.util.concurrent.locks包支持更復(fù)雜的鎖定語(yǔ)法,我們不會(huì)詳細(xì)檢查這個(gè)包,而是將重點(diǎn)放在其最基本的接口Lock上。 Lock對(duì)象的工作方式與同步代碼使用的隱式鎖定非常相似,與隱式鎖一樣,一次只有一個(gè)線程可以擁有一個(gè)Lock對(duì)象,Lock對(duì)象還通過其關(guān)聯(lián)的Condition對(duì)象支持wait/notif...
閱讀 937·2021-10-27 14:14
閱讀 1754·2021-10-11 10:59
閱讀 1327·2019-08-30 13:13
閱讀 3164·2019-08-29 15:17
閱讀 2762·2019-08-29 13:48
閱讀 502·2019-08-26 13:36
閱讀 2092·2019-08-26 13:25
閱讀 866·2019-08-26 12:24