阻塞隊(duì)列和線程池

1.阻塞隊(duì)列

1)支持阻塞的插入方法:意思是當(dāng)隊(duì)列滿時(shí)恬试,隊(duì)列會(huì)阻塞插入元素的線程劝枣,直到隊(duì)列不滿硝岗。
2)支持阻塞的移除方法:意思是在隊(duì)列為空時(shí)朴摊,獲取元素的線程會(huì)等待隊(duì)列變?yōu)榉强铡?br> 在并發(fā)編程中使用生產(chǎn)者和消費(fèi)者模式能夠解決絕大多數(shù)并發(fā)問題。該模式通過平衡生產(chǎn)線程和消費(fèi)線程的工作能力來提高程序整體處理數(shù)據(jù)的速度千扔。

  • BlockingQueue常用方法
    BlockingQueue
  • 常用阻塞隊(duì)列
    ArrayBlockingQueue:一個(gè)由數(shù)組結(jié)構(gòu)組成的有界阻塞隊(duì)列憎妙。
    LinkedBlockingQueue:一個(gè)由鏈表結(jié)構(gòu)組成的有界阻塞隊(duì)列。
    PriorityBlockingQueue:一個(gè)支持優(yōu)先級(jí)排序的無界阻塞隊(duì)列曲楚。
    DelayQueue:一個(gè)使用優(yōu)先級(jí)隊(duì)列實(shí)現(xiàn)的無界阻塞隊(duì)列厘唾。
    SynchronousQueue:一個(gè)不存儲(chǔ)元素的阻塞隊(duì)列。
    LinkedTransferQueue:一個(gè)由鏈表結(jié)構(gòu)組成的無界阻塞隊(duì)列龙誊。
    LinkedBlockingDeque:一個(gè)由鏈表結(jié)構(gòu)組成的雙向阻塞隊(duì)列抚垃。

  • 有界無界?
    有界隊(duì)列就是長度有限趟大,滿了以后生產(chǎn)者會(huì)阻塞鹤树,無界隊(duì)列就是里面能放無數(shù)的東西而不會(huì)因?yàn)殛?duì)列長度限制被阻塞。

2.線程池

  • 為什么要用線程池护昧?
    第一:降低資源消耗魂迄。
    第二:提高響應(yīng)速度。
    第三:提高線程的可管理性惋耙。


    線程池繼承關(guān)系
  • 線程池的創(chuàng)建各個(gè)參數(shù)含義

public ThreadPoolExecutor(int corePoolSize,int maximumPoolSize,
      long keepAliveTime,TimeUnit unit,
      BlockingQueue<Runnable> workQueue,
      ThreadFactory threadFactory,
      RejectedExecutionHandler handler)

1.corePoolSize : 線程池中的核心線程數(shù)
2.maximumPoolSize : 線程池中允許的最大線程數(shù)
3.keepAliveTime : 線程空閑時(shí)的存活時(shí)間
4.TimeUnit : keepAliveTime的時(shí)間單位
5.workQueue : workQueue必須是BlockingQueue阻塞隊(duì)列捣炬。當(dāng)線程池中的線程數(shù)超過它的corePoolSize的時(shí)候熊昌,線程會(huì)進(jìn)入阻塞隊(duì)列進(jìn)行阻塞等待
6.threadFactory : 創(chuàng)建線程的工廠,通過自定義的線程工廠可以給每個(gè)新建的線程設(shè)置一個(gè)具有識(shí)別度的線程名湿酸,當(dāng)然還可以更加自由的對(duì)線程做更多的設(shè)置
7.RejectedExecutionHandler : 線程池的飽和策略婿屹,當(dāng)阻塞隊(duì)列滿了,且沒有空閑的工作線程推溃,如果繼續(xù)提交任務(wù)昂利,必須采取一種策略處理該任務(wù)

  • 線程池的工作機(jī)制
    1)如果當(dāng)前運(yùn)行的線程少于corePoolSize,則創(chuàng)建新線程來執(zhí)行任務(wù)(注意铁坎,執(zhí)行這一步驟需要獲取全局鎖)蜂奸。
    2)如果運(yùn)行的線程等于或多于corePoolSize,則將任務(wù)加入BlockingQueue硬萍。
    3)如果無法將任務(wù)加入BlockingQueue(隊(duì)列已滿)扩所,則創(chuàng)建新的線程來處理任務(wù)。
    4)如果創(chuàng)建新線程將使當(dāng)前運(yùn)行的線程超出maximumPoolSize朴乖,任務(wù)將被拒絕祖屏,并調(diào)用RejectedExecutionHandler.rejectedExecution()方法。

  • 合理地配置線程池
    CPU密集型任務(wù): Runtime.getRuntime().availableProcessors()配置最大線程數(shù)
    IO密集型任務(wù) : 線程數(shù) :機(jī)器CPU核心數(shù)*2
    混合型任務(wù) : 線程池拆分

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末买羞,一起剝皮案震驚了整個(gè)濱河市袁勺,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌畜普,老刑警劉巖期丰,帶你破解...
    沈念sama閱讀 211,290評(píng)論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異吃挑,居然都是意外死亡咐汞,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,107評(píng)論 2 385
  • 文/潘曉璐 我一進(jìn)店門儒鹿,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人几晤,你說我怎么就攤上這事约炎。” “怎么了蟹瘾?”我有些...
    開封第一講書人閱讀 156,872評(píng)論 0 347
  • 文/不壞的土叔 我叫張陵圾浅,是天一觀的道長。 經(jīng)常有香客問我憾朴,道長狸捕,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,415評(píng)論 1 283
  • 正文 為了忘掉前任众雷,我火速辦了婚禮灸拍,結(jié)果婚禮上做祝,老公的妹妹穿的比我還像新娘。我一直安慰自己鸡岗,他們只是感情好混槐,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,453評(píng)論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著轩性,像睡著了一般声登。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上揣苏,一...
    開封第一講書人閱讀 49,784評(píng)論 1 290
  • 那天悯嗓,我揣著相機(jī)與錄音,去河邊找鬼卸察。 笑死脯厨,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蛾派。 我是一名探鬼主播俄认,決...
    沈念sama閱讀 38,927評(píng)論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼洪乍!你這毒婦竟也來了眯杏?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,691評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤壳澳,失蹤者是張志新(化名)和其女友劉穎岂贩,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體巷波,經(jīng)...
    沈念sama閱讀 44,137評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡萎津,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,472評(píng)論 2 326
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了抹镊。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片锉屈。...
    茶點(diǎn)故事閱讀 38,622評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖垮耳,靈堂內(nèi)的尸體忽然破棺而出颈渊,到底是詐尸還是另有隱情,我是刑警寧澤终佛,帶...
    沈念sama閱讀 34,289評(píng)論 4 329
  • 正文 年R本政府宣布俊嗽,位于F島的核電站,受9級(jí)特大地震影響铃彰,放射性物質(zhì)發(fā)生泄漏绍豁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,887評(píng)論 3 312
  • 文/蒙蒙 一牙捉、第九天 我趴在偏房一處隱蔽的房頂上張望竹揍。 院中可真熱鬧敬飒,春花似錦、人聲如沸鬼佣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,741評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽晶衷。三九已至蓝纲,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間晌纫,已是汗流浹背税迷。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評(píng)論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留锹漱,地道東北人箭养。 一個(gè)月前我還...
    沈念sama閱讀 46,316評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像哥牍,于是被迫代替她去往敵國和親毕泌。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,490評(píng)論 2 348

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