ArrayBlockingQueue與LinkedBlockingQueue區(qū)別

參考:https://cloud.tencent.com/developer/article/1340017

內(nèi)存方面

ArrayBlockingQueue

用于存儲(chǔ)隊(duì)列元素的存儲(chǔ)空間是預(yù)先分配的柳琢,使用過(guò)程中內(nèi)存開銷較小(無(wú)須動(dòng)態(tài)申請(qǐng)存儲(chǔ)空間)

LinkedBlockingQueue

用于存儲(chǔ)隊(duì)列元素的存儲(chǔ)空間是在其使用過(guò)程中動(dòng)態(tài)分配的,因此它可能會(huì)增加JVM垃圾回收的負(fù)擔(dān)诗茎。

有界無(wú)界

ArrayBlockingQueue

有界锻煌,適合已知最大存儲(chǔ)容量的場(chǎng)景

LinkedBlockingQueue

可有界可以無(wú)界

吞吐量

LinkedBlockingQueue在大多數(shù)并發(fā)的場(chǎng)景下吞吐量比ArrayBlockingQueue赶舆,但是性能不穩(wěn)定。

Linked queues typically have higher throughput than array-based queues but less predictable performance in most concurrent applications.

這個(gè)主要針對(duì)LinkedBlockingQueue是無(wú)界的場(chǎng)景來(lái)說(shuō)璃俗,由于無(wú)界套利,所以offer以及poll的吞吐量通常比ArrayBlockingQueue高推励。

應(yīng)用場(chǎng)景

按照適用的并發(fā)強(qiáng)度從低到高排列如下:

LinkedList/ArrayList ? 非線程安全鹤耍,不能用于并發(fā)場(chǎng)景(List的方法支持棧和隊(duì)列的操作,因此可以用List封裝成stack和queue)

Collections.synchronizedList ? 使用wrapper class封裝验辞,每個(gè)方法都用synchronized(mutex:Object)做了同步

LinkedBlockingQueue?? 采用了鎖分離的設(shè)計(jì)稿黄,避免了讀/寫操作沖突,且自動(dòng)負(fù)載均衡跌造,可以有界杆怕。BlockingQueue在生產(chǎn)-消費(fèi)模式下首選【Iterator安全,不保證數(shù)據(jù)一致性】

ConcurrentLinkedQueue ?適用于高并發(fā)讀寫操作壳贪,理論上有最高的吞吐量陵珍,無(wú)界,不保證數(shù)據(jù)訪問(wèn)實(shí)時(shí)一致性违施,Iterator不拋出并發(fā)修改異常互纯,采用CAS機(jī)制實(shí)現(xiàn)無(wú)鎖訪問(wèn)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末磕蒲,一起剝皮案震驚了整個(gè)濱河市留潦,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌辣往,老刑警劉巖兔院,帶你破解...
    沈念sama閱讀 212,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異站削,居然都是意外死亡坊萝,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,755評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門许起,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)十偶,“玉大人,你說(shuō)我怎么就攤上這事街氢〕都” “怎么了睦袖?”我有些...
    開封第一講書人閱讀 158,369評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵珊肃,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我馅笙,道長(zhǎng)伦乔,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,799評(píng)論 1 285
  • 正文 為了忘掉前任董习,我火速辦了婚禮烈和,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘皿淋。我一直安慰自己招刹,他們只是感情好恬试,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,910評(píng)論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著疯暑,像睡著了一般训柴。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上妇拯,一...
    開封第一講書人閱讀 50,096評(píng)論 1 291
  • 那天幻馁,我揣著相機(jī)與錄音,去河邊找鬼越锈。 笑死仗嗦,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的甘凭。 我是一名探鬼主播稀拐,決...
    沈念sama閱讀 39,159評(píng)論 3 411
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼丹弱!你這毒婦竟也來(lái)了钩蚊?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,917評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤蹈矮,失蹤者是張志新(化名)和其女友劉穎砰逻,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體泛鸟,經(jīng)...
    沈念sama閱讀 44,360評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡蝠咆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,673評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了北滥。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片刚操。...
    茶點(diǎn)故事閱讀 38,814評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖再芋,靈堂內(nèi)的尸體忽然破棺而出菊霜,到底是詐尸還是另有隱情,我是刑警寧澤济赎,帶...
    沈念sama閱讀 34,509評(píng)論 4 334
  • 正文 年R本政府宣布鉴逞,位于F島的核電站,受9級(jí)特大地震影響司训,放射性物質(zhì)發(fā)生泄漏构捡。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,156評(píng)論 3 317
  • 文/蒙蒙 一壳猜、第九天 我趴在偏房一處隱蔽的房頂上張望勾徽。 院中可真熱鬧,春花似錦统扳、人聲如沸喘帚。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)吹由。三九已至涡匀,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間溉知,已是汗流浹背陨瘩。 一陣腳步聲響...
    開封第一講書人閱讀 32,123評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留级乍,地道東北人舌劳。 一個(gè)月前我還...
    沈念sama閱讀 46,641評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像玫荣,于是被迫代替她去往敵國(guó)和親甚淡。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,728評(píng)論 2 351

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