Java集合源碼分析之Queue(二):接口Deque

Deque全稱為double ended queue,即雙向隊(duì)列,它允許在兩側(cè)插入或刪除元素斑匪,同時(shí)也建議我們不要向其中插入null值。除此之外锋勺,其余特性則和父級(jí)Queue類似蚀瘸。Deque大多數(shù)情況下不會(huì)限制元素的數(shù)量,但這不是必須的庶橱。

Deque中定義的方法主要分為四部分贮勃,第一部分就如Deque定義所言,提供兩側(cè)插入或刪除的方法苏章。第二部分是繼承自Queue的實(shí)現(xiàn)寂嘉。第三部分表示如果要基于此實(shí)現(xiàn)一個(gè)Stack,需要實(shí)現(xiàn)的方法枫绅。最后一部分是繼承自Collection的方法撮奏。

兩側(cè)插入给涕、刪除

這里方法和Queue定義方式一致,但卻是針對(duì)兩側(cè)插入刪除的林艘。

//在隊(duì)首添加元素
void addFirst(E e);
//在隊(duì)首添加元素
boolean offerFirst(E e);

//在隊(duì)尾添加元素
void addLast(E e);
boolean offerLast(E e);

//刪除隊(duì)首元素
E removeFirst();
E pollFirst();

//刪除隊(duì)尾元素
E removeLast();
E pollLast();

//獲取隊(duì)首元素
E getFirst();
E peekFirst();

//獲取隊(duì)尾元素
E getLast();
E peekLast();

//刪除第一個(gè)事件瓢娜,大多數(shù)指的是刪除第一個(gè)和 o equals的元素
boolean removeFirstOccurrence(Object o);
//刪除最后一個(gè)事件审胚,大多數(shù)指的是刪除最后一個(gè)和 o equals的元素
boolean removeLastOccurrence(Object o);

與Queue對(duì)應(yīng)的方法

因?yàn)镼ueue遵循FIFO茬故,所以其方法在Deque中對(duì)應(yīng)關(guān)系有所改變虎谢,結(jié)合Deque的定義,我們很容易就想到它們的對(duì)應(yīng)關(guān)系:

//與addLast(E e)等價(jià)
boolean add(E e);

//與offerLast(E e)等價(jià)
boolean offer(E e);

//與removeFirst()等價(jià)
E remove();

//與pollFirst()等價(jià)
E poll();

//與getFirst()等價(jià)
E element();

//與peekFirst()等價(jià)
E peek();

實(shí)現(xiàn)Stack

Stack僅在一側(cè)支持插入刪除操作等操作酬诀,遵循LIFO原則。

//與addFirst()等價(jià)
void push(E e);

//與removeFirst()等價(jià)
E pop();

繼承于Collection的方法

這里主要關(guān)注兩個(gè)方法骆撇。

//順序是從隊(duì)首到隊(duì)尾
Iterator<E> iterator();

//順序是從隊(duì)尾到隊(duì)首
Iterator<E> descendingIterator();

好了瞒御,這個(gè)接口是不是相當(dāng)簡(jiǎn)單呢?接下來(lái)我們就看看一個(gè)真正的實(shí)現(xiàn)類神郊,ArrayDeque肴裙,的具體內(nèi)容吧趾唱。

上一篇:Java集合源碼分析之Queue(一):超級(jí)接口Queue

下一篇:Java集合源碼分析之Queue(三):ArrayDeque


我是飛機(jī)醬,如果您喜歡我的文章蜻懦,可以關(guān)注我~

編程之路甜癞,道阻且長(zhǎng)。唯宛乃,路漫漫其修遠(yuǎn)兮悠咱,吾將上下而求索。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末征炼,一起剝皮案震驚了整個(gè)濱河市析既,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌谆奥,老刑警劉巖眼坏,帶你破解...
    沈念sama閱讀 206,482評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異酸些,居然都是意外死亡宰译,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,377評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門魄懂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)沿侈,“玉大人,你說(shuō)我怎么就攤上這事逢渔±呒幔” “怎么了?”我有些...
    開封第一講書人閱讀 152,762評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵肃廓,是天一觀的道長(zhǎng)智厌。 經(jīng)常有香客問(wèn)我,道長(zhǎng)盲赊,這世上最難降的妖魔是什么铣鹏? 我笑而不...
    開封第一講書人閱讀 55,273評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮哀蘑,結(jié)果婚禮上诚卸,老公的妹妹穿的比我還像新娘。我一直安慰自己绘迁,他們只是感情好合溺,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,289評(píng)論 5 373
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著缀台,像睡著了一般棠赛。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,046評(píng)論 1 285
  • 那天睛约,我揣著相機(jī)與錄音鼎俘,去河邊找鬼。 笑死辩涝,一個(gè)胖子當(dāng)著我的面吹牛贸伐,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播怔揩,決...
    沈念sama閱讀 38,351評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼捉邢,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了沧踏?” 一聲冷哼從身側(cè)響起歌逢,我...
    開封第一講書人閱讀 36,988評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎翘狱,沒(méi)想到半個(gè)月后秘案,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,476評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡潦匈,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,948評(píng)論 2 324
  • 正文 我和宋清朗相戀三年阱高,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片茬缩。...
    茶點(diǎn)故事閱讀 38,064評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡赤惊,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出凰锡,到底是詐尸還是另有隱情未舟,我是刑警寧澤,帶...
    沈念sama閱讀 33,712評(píng)論 4 323
  • 正文 年R本政府宣布掂为,位于F島的核電站裕膀,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏勇哗。R本人自食惡果不足惜昼扛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,261評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望欲诺。 院中可真熱鬧抄谐,春花似錦、人聲如沸扰法。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,264評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)塞颁。三九已至挣惰,卻和暖如春卧斟,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背憎茂。 一陣腳步聲響...
    開封第一講書人閱讀 31,486評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留锤岸,地道東北人竖幔。 一個(gè)月前我還...
    沈念sama閱讀 45,511評(píng)論 2 354
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像是偷,于是被迫代替她去往敵國(guó)和親拳氢。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,802評(píng)論 2 345

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

  • 在日常生活中蛋铆,排隊(duì)幾乎隨處可見馋评,上地鐵要排隊(duì),買火車票要排隊(duì)刺啦,就連出門吃個(gè)大餐留特,也要排隊(duì)。玛瘸。蜕青。之前研究的Array...
    大大紙飛機(jī)閱讀 3,611評(píng)論 13 7
  • 在經(jīng)過(guò)一次沒(méi)有準(zhǔn)備的面試后,發(fā)現(xiàn)自己雖然寫了兩年的android代碼糊渊,基礎(chǔ)知識(shí)卻忘的差不多了右核。這是程序員的大忌,沒(méi)...
    猿來(lái)如癡閱讀 2,829評(píng)論 3 10
  • java筆記第一天 == 和 equals ==比較的比較的是兩個(gè)變量的值是否相等渺绒,對(duì)于引用型變量表示的是兩個(gè)變量...
    jmychou閱讀 1,485評(píng)論 0 3
  • 四年的時(shí)光匆匆而過(guò)贺喝,我還未察覺(jué),竟已到離別的時(shí)刻宗兼。感謝陪伴了我這么久的你們——我的室友們躏鱼。 不得不說(shuō)我們的相遇是一...
    南木的小屋閱讀 438評(píng)論 2 2
  • 孤獨(dú)的時(shí)候讓雨把心澆的濕噠噠的≌肼或許我不該為一點(diǎn)小事跟自己斗氣的挠他,讓自己的胃受折磨,可是就是很莫名其妙的發(fā)呆了開始...
    六六宗閱讀 376評(píng)論 0 2