JUC(二) | 線程池淺談

前面簡單學(xué)習(xí)了JUC同步輔助類,今天一起走進(jìn)線程池的美妙新世界。

一、從新建線程池談起

    public static ExecutorService newFixedThreadPool(int nThreads) {
        return new ThreadPoolExecutor(nThreads, nThreads,
                                      0L, TimeUnit.MILLISECONDS,
                                      new LinkedBlockingQueue<Runnable>());
    }    
    public ThreadPoolExecutor(int corePoolSize,
                              int maximumPoolSize,
                              long keepAliveTime,
                              TimeUnit unit,
                              BlockingQueue<Runnable> workQueue) {
        this(corePoolSize, maximumPoolSize, keepAliveTime, unit, workQueue,
             Executors.defaultThreadFactory(), defaultHandler);
    }

  • 類的區(qū)別
    Executor是執(zhí)行者接口俐筋,通過execute方法執(zhí)行Runnable任務(wù);
    ExecutorService是執(zhí)行者服務(wù)接口严衬,通過submit將任務(wù)提交給Executor執(zhí)行澄者;
    ThreadPoolExecutor是真正的實(shí)現(xiàn)類;
    Executors是靜態(tài)工廠類请琳,可以返回ExecutorService等粱挡;

  • 參數(shù)概念
    corePoolSize : 線程池中允許同時運(yùn)行的線程數(shù);
    maximumPoolSize : 線程池中允許創(chuàng)建的最大線程數(shù)俄精;
    keepAliveTime:線程池空閑后询筏,超過此時間的線程會被終止;
    workQueue :線程任務(wù)阻塞隊(duì)列竖慧;
    defaultThreadFactory : 返回線程工廠屈留,線程池中的線程均是由線程工廠創(chuàng)建;
    defaultHandler:任務(wù)添加到線程池中测蘑,線程池拒絕時采取的策略灌危;

二、以execute方法為重

    public void execute(Runnable command) {
        if (command == null)
            throw new NullPointerException();
        int c = ctl.get();
        //策略一:線程池中運(yùn)行數(shù)量小于corePoolSize時碳胳,直接新建任務(wù)
        if (workerCountOf(c) < corePoolSize) {
            if (addWorker(command, true))
                return;
            c = ctl.get();
        }
        //策略二:線程池中大于等于corePoolSize時勇蝙,且線程池狀態(tài)允許時,將任務(wù)添加到阻塞隊(duì)列中
        if (isRunning(c) && workQueue.offer(command)) {
            int recheck = ctl.get();
            if (! isRunning(recheck) && remove(command))
                reject(command);
            else if (workerCountOf(recheck) == 0)
                addWorker(null, false);
        }
        //策略三:線程池中大于等于corePoolSize時挨约,且線程池狀態(tài)不允許時味混,直接新建任務(wù)
        else if (!addWorker(command, false))
            reject(command);
    }
  • addWork源碼解讀
  • 上面代碼中多次談到線程池狀態(tài)及拒絕策略产雹,下一步深入理解

三、線程池狀態(tài)及轉(zhuǎn)換

  • 與線程的五種狀態(tài)不同翁锡,線程池的五種狀態(tài)及其轉(zhuǎn)換如下圖所示:
線程池的狀態(tài).png

Running:能接受新任務(wù)蔓挖,且處理已添加任務(wù);(對應(yīng)于isRunning檢測)
ShutDown:不能接受新任務(wù)馆衔,可處理已添加任務(wù)瘟判;
Stop:不能接受新任務(wù),且會中斷已處理任務(wù)角溃;
Tidying:所有任務(wù)已經(jīng)終止拷获;
Terminated:Tidying狀態(tài)后,執(zhí)行鉤子函數(shù)terminate减细,進(jìn)入此狀態(tài)匆瓜;

四、拒絕策略

AbortPolicy:當(dāng)任務(wù)添加到線程池中被拒絕時未蝌,它將拋出 RejectedExecutionException 異常驮吱;
CallerRunsPolicy:當(dāng)任務(wù)添加到線程池中被拒絕時,會在線程池當(dāng)前正在運(yùn)行的Thread線程池中處理被拒絕的任務(wù)萧吠;
DiscardOldestPolicy:當(dāng)任務(wù)添加到線程池中被拒絕時左冬,線程池會放棄等待隊(duì)列中最舊的未處理任務(wù),然后將被拒絕的任務(wù)添加到等待隊(duì)列中怎憋;
DiscardPolicy:當(dāng)任務(wù)添加到線程池中被拒絕時,線程池將丟棄被拒絕的任務(wù)九昧;

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末绊袋,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子铸鹰,更是在濱河造成了極大的恐慌癌别,老刑警劉巖,帶你破解...
    沈念sama閱讀 223,207評論 6 521
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蹋笼,死亡現(xiàn)場離奇詭異展姐,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)剖毯,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,455評論 3 400
  • 文/潘曉璐 我一進(jìn)店門圾笨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人逊谋,你說我怎么就攤上這事擂达。” “怎么了胶滋?”我有些...
    開封第一講書人閱讀 170,031評論 0 366
  • 文/不壞的土叔 我叫張陵板鬓,是天一觀的道長悲敷。 經(jīng)常有香客問我,道長俭令,這世上最難降的妖魔是什么后德? 我笑而不...
    開封第一講書人閱讀 60,334評論 1 300
  • 正文 為了忘掉前任,我火速辦了婚禮抄腔,結(jié)果婚禮上瓢湃,老公的妹妹穿的比我還像新娘。我一直安慰自己妓柜,他們只是感情好箱季,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,322評論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著棍掐,像睡著了一般藏雏。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上作煌,一...
    開封第一講書人閱讀 52,895評論 1 314
  • 那天掘殴,我揣著相機(jī)與錄音,去河邊找鬼粟誓。 笑死奏寨,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的鹰服。 我是一名探鬼主播病瞳,決...
    沈念sama閱讀 41,300評論 3 424
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼悲酷!你這毒婦竟也來了套菜?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 40,264評論 0 277
  • 序言:老撾萬榮一對情侶失蹤设易,失蹤者是張志新(化名)和其女友劉穎逗柴,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體顿肺,經(jīng)...
    沈念sama閱讀 46,784評論 1 321
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡戏溺,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,870評論 3 343
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了屠尊。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片旷祸。...
    茶點(diǎn)故事閱讀 40,989評論 1 354
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖讼昆,靈堂內(nèi)的尸體忽然破棺而出肋僧,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 36,649評論 5 351
  • 正文 年R本政府宣布嫌吠,位于F島的核電站止潘,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏辫诅。R本人自食惡果不足惜凭戴,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,331評論 3 336
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望炕矮。 院中可真熱鬧么夫,春花似錦、人聲如沸肤视。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,814評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽邢滑。三九已至腐螟,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間困后,已是汗流浹背乐纸。 一陣腳步聲響...
    開封第一講書人閱讀 33,940評論 1 275
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留摇予,地道東北人汽绢。 一個月前我還...
    沈念sama閱讀 49,452評論 3 379
  • 正文 我出身青樓,卻偏偏與公主長得像侧戴,于是被迫代替她去往敵國和親宁昭。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,995評論 2 361

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