線程池企業(yè)級(jí)常規(guī)使用實(shí)例

多線程在學(xué)校的時(shí)候其實(shí)用的非常少蚣常,甚至幾乎用不到市咽,但是在公司是不一樣的,用的非常多抵蚊,畢竟用戶數(shù)據(jù)量十分的大施绎,曾經(jīng)實(shí)習(xí)我在一個(gè)項(xiàng)目里面做過一個(gè)數(shù)據(jù)處理,是計(jì)算這人和人之間的關(guān)系度贞绳,從而推出哪幾個(gè)人的親密度達(dá)到要求谷醉,如果不用多線程,要把這一批數(shù)據(jù)計(jì)算完冈闭,那么是需要大概一年時(shí)間俱尼,后來把時(shí)間縮短到了8天,降低了兩個(gè)數(shù)量級(jí)萎攒。

1遇八、我一般是這樣用線程池的,首先建立一個(gè)池子躺酒,當(dāng)然有時(shí)候有現(xiàn)成的池子給你用押蚤,看業(yè)務(wù)是自己創(chuàng)建還是用公共的。

private static final ExecutorService? commentExecutor =new ThreadPoolExecutor(20, 20, 1L,?

TimeUnit.MINUTES, new ArrayBlockingQueue<>(30),? r ->new Thread(r,"comment"));? //新建立一個(gè)池子羹应,看業(yè)務(wù)哈揽碘,一般這樣是可以的,各個(gè)參數(shù)這里不展開說园匹,后面會(huì)解釋的雳刺,看業(yè)務(wù)設(shè)計(jì)參數(shù)值;

2裸违、然后往池子里面提任務(wù)

List<T>?commentInfos = Lists.newCopyOnWriteArrayList(); //一般情況下ArrayList就可以了掖桦,這是用guava的

commentExecutor.submit(() -> {

try {

commentInfos.add(buildComment(reqParam));

}catch (Exception e) {

logger.info("buildComment error", e);

}

})

buildComment(reqParam) 這個(gè)是執(zhí)行任務(wù)的函數(shù),計(jì)算完后結(jié)果放到了commentInfos 集合中供汛;

如果是批量計(jì)算型任務(wù)枪汪,而且事先能知道批量數(shù),可以結(jié)合CountDownLatch使用怔昨,目的可以通過它來控制所有線程計(jì)算完后再往下走雀久;

也是比較常用的;

3趁舀、CountDownLatch 結(jié)合使用

try {

final CountDownLatch latch =new CountDownLatch(reqParam.getProductNos().size()); //事先獲取到批次

reqParam.getProductNos().forEach(p ->? //遍歷

commentExecutor.submit(() -> {? //每一個(gè)批次提交到池子里面

try {

commentInfos.add(buildComment(p,reqParam));? //開始運(yùn)算赖捌,運(yùn)算的結(jié)果放到commentInfos

}catch (Exception e) {

logger.info("buildComment error", e);

}finally {

latch.countDown(); //每個(gè)線程完成就釋放掉一個(gè)latch

}

})

);

latch.await(); //等待所有的latch釋放掉,也就是每一個(gè)線程都執(zhí)行完成

}catch (Exception e) {

logger.error("異常", e);

return WebResponse.fail(e.getMessage());

}finally {

logger.info("結(jié)果 commentInfos:{},計(jì)算耗時(shí):{}", JsonUtil.encode(commentInfos), stopwatch.elapsed(TimeUnit.MILLISECONDS));

}

可能沒用過線程池的小伙伴第一次看有點(diǎn)不明白矮烹,沒關(guān)系越庇,等以后工作中用到再翻翻就好了罩锐。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市卤唉,隨后出現(xiàn)的幾起案子涩惑,更是在濱河造成了極大的恐慌,老刑警劉巖搬味,帶你破解...
    沈念sama閱讀 221,406評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件境氢,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡碰纬,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,395評(píng)論 3 398
  • 文/潘曉璐 我一進(jìn)店門问芬,熙熙樓的掌柜王于貴愁眉苦臉地迎上來悦析,“玉大人,你說我怎么就攤上這事此衅∏看鳎” “怎么了?”我有些...
    開封第一講書人閱讀 167,815評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵挡鞍,是天一觀的道長(zhǎng)骑歹。 經(jīng)常有香客問我,道長(zhǎng)墨微,這世上最難降的妖魔是什么道媚? 我笑而不...
    開封第一講書人閱讀 59,537評(píng)論 1 296
  • 正文 為了忘掉前任,我火速辦了婚禮翘县,結(jié)果婚禮上最域,老公的妹妹穿的比我還像新娘。我一直安慰自己锈麸,他們只是感情好镀脂,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,536評(píng)論 6 397
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著忘伞,像睡著了一般薄翅。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上氓奈,一...
    開封第一講書人閱讀 52,184評(píng)論 1 308
  • 那天翘魄,我揣著相機(jī)與錄音,去河邊找鬼探颈。 笑死熟丸,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的伪节。 我是一名探鬼主播光羞,決...
    沈念sama閱讀 40,776評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼绩鸣,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了纱兑?” 一聲冷哼從身側(cè)響起呀闻,我...
    開封第一講書人閱讀 39,668評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎潜慎,沒想到半個(gè)月后捡多,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,212評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡铐炫,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,299評(píng)論 3 340
  • 正文 我和宋清朗相戀三年垒手,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片倒信。...
    茶點(diǎn)故事閱讀 40,438評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡科贬,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出鳖悠,到底是詐尸還是另有隱情榜掌,我是刑警寧澤,帶...
    沈念sama閱讀 36,128評(píng)論 5 349
  • 正文 年R本政府宣布乘综,位于F島的核電站憎账,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏卡辰。R本人自食惡果不足惜胞皱,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,807評(píng)論 3 333
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望看政。 院中可真熱鬧朴恳,春花似錦、人聲如沸允蚣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,279評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)嚷兔。三九已至森渐,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間冒晰,已是汗流浹背同衣。 一陣腳步聲響...
    開封第一講書人閱讀 33,395評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留壶运,地道東北人耐齐。 一個(gè)月前我還...
    沈念sama閱讀 48,827評(píng)論 3 376
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親埠况。 傳聞我的和親對(duì)象是個(gè)殘疾皇子耸携,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,446評(píng)論 2 359

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