DelayQueue基本簡(jiǎn)介

DelayQueue基本簡(jiǎn)介

DelayQueue是一個(gè)無界阻塞隊(duì)列言疗,只有在延遲期滿時(shí)才能從中提取元素。該隊(duì)列的頭部是延遲期滿后保存時(shí)間最長(zhǎng)的Delayed 元素。

DelayQueue是一個(gè)用來延時(shí)處理的隊(duì)列速客,所謂延時(shí)處理就是說可以為隊(duì)列中元素設(shè)定一個(gè)過期時(shí)間渣触,相關(guān)的操作受到這個(gè)設(shè)定時(shí)間的控制诽俯。

DelayQueue使用場(chǎng)景

  1. 關(guān)閉空閑連接敲才。服務(wù)器中晦墙,有很多客戶端的連接,空閑一段時(shí)間之后需要關(guān)閉之歧斟。
  2. 緩存纯丸。緩存中的對(duì)象,超過了空閑時(shí)間静袖,需要從緩存中移出觉鼻。
  3. 任務(wù)超時(shí)處理。在網(wǎng)絡(luò)協(xié)議滑動(dòng)窗口請(qǐng)求應(yīng)答式交互時(shí)队橙,處理超時(shí)未響應(yīng)的請(qǐng)求坠陈。

如果不使用DelayQueue,那么常規(guī)的解決辦法就是:使用一個(gè)后臺(tái)線程喘帚,遍歷所有對(duì)象畅姊,挨個(gè)檢查。這種笨笨的辦法簡(jiǎn)單好用吹由,但是對(duì)象數(shù)量過多時(shí),可能存在性能問題朱嘴,檢查間隔時(shí)間不好設(shè)置倾鲫,間隔時(shí)間過大粗合,影響精確度,過小則存在效率問題乌昔。而且做不到按超時(shí)的時(shí)間順序處理隙疚。

DelayQueue基本原理

  • 首先,這種隊(duì)列中只能存放實(shí)現(xiàn)Delayed接口的對(duì)象磕道,而此接口有兩個(gè)需要實(shí)現(xiàn)的方法供屉。最重要的就是getDelay,這個(gè)方法需要返回對(duì)象過期前的時(shí)間溺蕉。簡(jiǎn)單說伶丐,隊(duì)列在某些方法處理前,會(huì)調(diào)用此方法來判斷對(duì)象有沒有超時(shí)疯特。

  • 其次哗魂,DelayQueue是一個(gè)BlockingQueue,其特化的參數(shù)是Delayed漓雅。(不了解BlockingQueue的同學(xué)录别,先去了解BlockingQueue再看本文)
    Delayed擴(kuò)展了Comparable接口,比較的基準(zhǔn)為延時(shí)的時(shí)間值邻吞,Delayed接口的實(shí)現(xiàn)類getDelay的返回值應(yīng)為固定值(final)组题。DelayQueue內(nèi)部是使用PriorityQueue實(shí)現(xiàn)的。

  • 總結(jié)抱冷,DelayQueue的關(guān)鍵元素BlockingQueue崔列、PriorityQueue、Delayed徘层【唬可以這么說,DelayQueue是一個(gè)使用優(yōu)先隊(duì)列(PriorityQueue)實(shí)現(xiàn)的BlockingQueue趣效,優(yōu)先隊(duì)列的比較基準(zhǔn)值是時(shí)間瘦癌。本質(zhì)上即:

DelayQueue = BlockingQueue +PriorityQueue + Delayed

基本定義如下
public interface Comparable<T> {
    public int compareTo(T o);
}

public interface Delayed extends Comparable<Delayed> {
    long getDelay(TimeUnit unit);
}

public class DelayQueue<E extends Delayed> implements BlockingQueue<E> { 
    private final PriorityQueue<E> q = new PriorityQueue<E>();
}
DelayQueue內(nèi)部的實(shí)現(xiàn)使用了一個(gè)優(yōu)先隊(duì)列。當(dāng)調(diào)用DelayQueue的offer方法時(shí)跷敬,把Delayed對(duì)象加入到優(yōu)先隊(duì)列q中讯私。如下:
public boolean offer(E e) {
    final ReentrantLock lock = this.lock;
    lock.lock();
    try {
        E first = q.peek();
        q.offer(e);
        if (first == null || e.compareTo(first) < 0)
            available.signalAll();
        return true;
    } finally {
        lock.unlock();
    }
}
DelayQueue的take方法,把優(yōu)先隊(duì)列q的first拿出來(peek)西傀,如果沒有達(dá)到延時(shí)閥值斤寇,則進(jìn)行await處理。如下:
public E take() throws InterruptedException {
    final ReentrantLock lock = this.lock;
    lock.lockInterruptibly();
    try {
        for (;;) {
            E first = q.peek();
            if (first == null) {
                available.await();
            } else {
                long delay =  first.getDelay(TimeUnit.NANOSECONDS);
                if (delay > 0) {
                    long tl = available.awaitNanos(delay);
                } else {
                    E x = q.poll();
                    assert x != null;
                    if (q.size() != 0)
                        available.signalAll(); // wake up other takers
                    return x;

                }
            }
        }
    } finally {
        lock.unlock();
    }
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末拥褂,一起剝皮案震驚了整個(gè)濱河市娘锁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌饺鹃,老刑警劉巖莫秆,帶你破解...
    沈念sama閱讀 222,807評(píng)論 6 518
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件间雀,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡镊屎,警方通過查閱死者的電腦和手機(jī)惹挟,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,284評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來缝驳,“玉大人连锯,你說我怎么就攤上這事∮糜” “怎么了运怖?”我有些...
    開封第一講書人閱讀 169,589評(píng)論 0 363
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)齿拂。 經(jīng)常有香客問我驳规,道長(zhǎng),這世上最難降的妖魔是什么署海? 我笑而不...
    開封第一講書人閱讀 60,188評(píng)論 1 300
  • 正文 為了忘掉前任吗购,我火速辦了婚禮,結(jié)果婚禮上砸狞,老公的妹妹穿的比我還像新娘捻勉。我一直安慰自己,他們只是感情好刀森,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,185評(píng)論 6 398
  • 文/花漫 我一把揭開白布踱启。 她就那樣靜靜地躺著,像睡著了一般研底。 火紅的嫁衣襯著肌膚如雪埠偿。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,785評(píng)論 1 314
  • 那天榜晦,我揣著相機(jī)與錄音冠蒋,去河邊找鬼。 笑死乾胶,一個(gè)胖子當(dāng)著我的面吹牛抖剿,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播识窿,決...
    沈念sama閱讀 41,220評(píng)論 3 423
  • 文/蒼蘭香墨 我猛地睜開眼斩郎,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了喻频?” 一聲冷哼從身側(cè)響起缩宜,我...
    開封第一講書人閱讀 40,167評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎甥温,沒想到半個(gè)月后脓恕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體膜宋,經(jīng)...
    沈念sama閱讀 46,698評(píng)論 1 320
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡窿侈,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,767評(píng)論 3 343
  • 正文 我和宋清朗相戀三年炼幔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片史简。...
    茶點(diǎn)故事閱讀 40,912評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡乃秀,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出圆兵,到底是詐尸還是另有隱情跺讯,我是刑警寧澤,帶...
    沈念sama閱讀 36,572評(píng)論 5 351
  • 正文 年R本政府宣布殉农,位于F島的核電站刀脏,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏超凳。R本人自食惡果不足惜愈污,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,254評(píng)論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望轮傍。 院中可真熱鬧暂雹,春花似錦、人聲如沸创夜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,746評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽驰吓。三九已至涧尿,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間檬贰,已是汗流浹背姑廉。 一陣腳步聲響...
    開封第一講書人閱讀 33,859評(píng)論 1 274
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留偎蘸,地道東北人庄蹋。 一個(gè)月前我還...
    沈念sama閱讀 49,359評(píng)論 3 379
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像迷雪,于是被迫代替她去往敵國(guó)和親限书。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,922評(píng)論 2 361

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