Java Concurrent Semaphore

前言

Semaphore一種通常用于維持?jǐn)?shù)量的信號(hào)量工具莉恼,在Java 并發(fā)中最常見的使用就是維持并發(fā)線程的個(gè)數(shù),正如之前提到的,并不是并發(fā)場(chǎng)景線程越多越好,應(yīng)該是跟對(duì)應(yīng)的業(yè)務(wù)場(chǎng)景及CPU數(shù)量共同決定诗茎。而需要維持?jǐn)?shù)量時(shí),我們大致就需要一個(gè)JUC里面Semaphore這樣一個(gè)信號(hào)量工具献汗。Semaphore 同樣依賴于AQS實(shí)現(xiàn)(shared)敢订,內(nèi)部持有一個(gè)Sync對(duì)象,同樣存在公平實(shí)現(xiàn)罢吃、非公平實(shí)現(xiàn)兩種模式(可以在構(gòu)造時(shí)指定fair參數(shù))枢析。

原理

每次線程執(zhí)行前夕都會(huì)從這里默認(rèn)通過一下許可,然后執(zhí)行完畢時(shí)釋放一下許可刃麸,根據(jù)維系的數(shù)量來決定當(dāng)前線程是該等待還是執(zhí)行。
簡(jiǎn)單看一下源碼司浪,實(shí)現(xiàn)蠻簡(jiǎn)單的
首先是持有AQS對(duì)象

public class Semaphore implements java.io.Serializable {
    private static final long serialVersionUID = -3222578661600680210L;
    /** All mechanics via AbstractQueuedSynchronizer subclass */
    private final Sync sync;

取許可及釋放操作

final int nonfairTryAcquireShared(int acquires) {
    for (;;) {
        int available = getState();
        int remaining = available - acquires;
        if (remaining < 0 ||
            compareAndSetState(available, remaining))
            return remaining;
    }
}
protected final boolean tryReleaseShared(int releases) {
    for (;;) {
        int current = getState();
        int next = current + releases;
        if (next < current) // overflow
            throw new Error("Maximum permit count exceeded");
        if (compareAndSetState(current, next))
            return true;
    }
}

公平非公平兩種實(shí)現(xiàn)版本:

/**
 * NonFair version
 */
static final class NonfairSync extends Sync {
    private static final long serialVersionUID = -2694183684443567898L;
    NonfairSync(int permits) {
        super(permits);
    }
    protected int tryAcquireShared(int acquires) {
        return nonfairTryAcquireShared(acquires);
    }
}
/**
 * Fair version
 */
static final class FairSync extends Sync {
    private static final long serialVersionUID = 2014338818796000944L;
    FairSync(int permits) {
        super(permits);
    }
    protected int tryAcquireShared(int acquires) {
        for (;;) {
            if (hasQueuedPredecessors())
                return -1;
            int available = getState();
            int remaining = available - acquires;
            if (remaining < 0 ||
                compareAndSetState(available, remaining))
                return remaining;
        }
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末泊业,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子啊易,更是在濱河造成了極大的恐慌吁伺,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,194評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件租谈,死亡現(xiàn)場(chǎng)離奇詭異篮奄,居然都是意外死亡捆愁,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,058評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門窟却,熙熙樓的掌柜王于貴愁眉苦臉地迎上來昼丑,“玉大人,你說我怎么就攤上這事夸赫∑械郏” “怎么了?”我有些...
    開封第一講書人閱讀 156,780評(píng)論 0 346
  • 文/不壞的土叔 我叫張陵茬腿,是天一觀的道長(zhǎng)呼奢。 經(jīng)常有香客問我,道長(zhǎng)切平,這世上最難降的妖魔是什么握础? 我笑而不...
    開封第一講書人閱讀 56,388評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮悴品,結(jié)果婚禮上禀综,老公的妹妹穿的比我還像新娘。我一直安慰自己他匪,他們只是感情好菇存,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,430評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著邦蜜,像睡著了一般依鸥。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上悼沈,一...
    開封第一講書人閱讀 49,764評(píng)論 1 290
  • 那天贱迟,我揣著相機(jī)與錄音,去河邊找鬼絮供。 笑死衣吠,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的壤靶。 我是一名探鬼主播缚俏,決...
    沈念sama閱讀 38,907評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼贮乳!你這毒婦竟也來了忧换?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,679評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤向拆,失蹤者是張志新(化名)和其女友劉穎亚茬,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體浓恳,經(jīng)...
    沈念sama閱讀 44,122評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡刹缝,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,459評(píng)論 2 325
  • 正文 我和宋清朗相戀三年碗暗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片梢夯。...
    茶點(diǎn)故事閱讀 38,605評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡言疗,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出厨疙,到底是詐尸還是另有隱情洲守,我是刑警寧澤,帶...
    沈念sama閱讀 34,270評(píng)論 4 329
  • 正文 年R本政府宣布沾凄,位于F島的核電站梗醇,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏撒蟀。R本人自食惡果不足惜叙谨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,867評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望保屯。 院中可真熱鬧手负,春花似錦、人聲如沸姑尺。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,734評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽切蟋。三九已至统捶,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間柄粹,已是汗流浹背喘鸟。 一陣腳步聲響...
    開封第一講書人閱讀 31,961評(píng)論 1 265
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留驻右,地道東北人什黑。 一個(gè)月前我還...
    沈念sama閱讀 46,297評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像堪夭,于是被迫代替她去往敵國(guó)和親愕把。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,472評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • 信號(hào)量-Semaphore Semaphore共享鎖的使用 信號(hào)量(Semaphore)森爽,又被稱為信號(hào)燈恨豁,在多線程...
    faunjoe閱讀 671評(píng)論 0 0
  • 作者: 一字馬胡 轉(zhuǎn)載標(biāo)志 【2017-11-03】 更新日志 導(dǎo)入 Semaphore實(shí)現(xiàn)為一種基于計(jì)數(shù)的信號(hào)...
    一字馬胡閱讀 9,318評(píng)論 0 14
  • 在你制造的長(zhǎng)夢(mèng)中,我得以轉(zhuǎn)生回到當(dāng)世拗秘。 ——題記 一、郭子延的實(shí)驗(yàn)室 我最受不了郭子延夸我祈惶,這個(gè)男人的贊美聽起來永...
    我住深海別墅閱讀 394評(píng)論 0 0
  • 不知不覺又到10點(diǎn)了雕旨,一會(huì)兒要睡覺了扮匠。 一天又過去了。 當(dāng)然我也沒那么在意一天凡涩,他就像匆匆走過的一步棒搜。 總期待空閑...
    部落10閱讀 805評(píng)論 0 0
  • 目錄 上一章 在某一個(gè)時(shí)刻翻起一段篇章,掀起一段回憶活箕,奏響一段樂曲力麸,想起一個(gè)人,一個(gè)你育韩。 拿的起的稱得上回憶克蚂,拿不...
    嘉晟閱讀 104評(píng)論 2 0