ThreadPoolExecutor execute 和 submit

ThreadPoolExecutor 除了execute 方法用來提交任務(wù)自阱,還有submit 方法,他們的區(qū)別就是后者有返回值米酬,其原理是在前者的基礎(chǔ)上使用了Future 接口沛豌。因此,我之前的示例改用submit 方法來實現(xiàn)會更加簡單淮逻。原因有二:

1琼懊、submit 方法提交的任務(wù)有返回值,方便判斷每個任務(wù)的最終運(yùn)行結(jié)果爬早,無需引入狀態(tài)標(biāo)識變量
2哼丈、future 的get方法是阻塞的,無需引入CountDownLatch 并發(fā)包工具也可以等待所有線程運(yùn)行完畢

直接上代碼

package com.yzy.test;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.*;
import java.util.concurrent.atomic.AtomicInteger;

public class Main2 {

    public static void main(String[] args) throws ExecutionException, InterruptedException {
        // 線程安全的計數(shù)器
        AtomicInteger totalRows = new AtomicInteger(0);

        // 創(chuàng)建線程池筛严,其中核心線程10醉旦,也是我期望的最大并發(fā)數(shù),最大線程數(shù)和隊列大小都為30桨啃,即我的總?cè)蝿?wù)數(shù)
        ThreadPoolExecutor executor = new ThreadPoolExecutor(10, 30, 60L, TimeUnit.SECONDS, new ArrayBlockingQueue<>(30));

        // 創(chuàng)建 Future 集合车胡,用來存儲Future 實例
        List<Future<Integer>> futureList = new ArrayList<>();

        for (int i = 0; i < 30; i++) {
            final int index = i;
            // 這里創(chuàng)建 Callable 實例,返回整型
            Future<Integer> future = executor.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    // 模擬異常的線程照瘾,返回0
                    if (index % 5 == 0) {
                        return 0;
                    }

                    int times = 0;
                    boolean loop = true;
                    // 模擬數(shù)據(jù)拉取過程可能需要分頁
                    while (loop) {
                        // 模擬每個任務(wù)需要分頁5次
                        if (times >= 5) {
                            break;
                        }
                        times++;

                        // 模擬計數(shù)
                        totalRows.incrementAndGet();
                        // 模擬耗時
                        try {
                            // 打印運(yùn)行情況
                            System.out.println(Thread.currentThread().getName() + ":" + index + ":" + times);
                            Thread.sleep(Long.valueOf(String.valueOf(new Double(Math.random() * 1000).intValue())));
                        } catch (InterruptedException e) {
                            e.printStackTrace();
                        }
                    }
                    // 成功返回1
                    return 1;
                }
            });

            futureList.add(future);
        }

        // 標(biāo)記多線程關(guān)閉匈棘,但不會立馬關(guān)閉
        executor.shutdown();

        boolean flag = true;
        for (Future<Integer> future : futureList) {
            // 獲取每一個線程的返回結(jié)果,如果該線程未完成析命,會阻塞
            if (future.get() == 0) {
                flag = false;
            }
        }

        if (flag) {
            System.out.println("全部成功了,計數(shù):" + totalRows.get());
        } else {
            System.out.println("失敗了");
        }
    }
}

運(yùn)行結(jié)果:

//省略若干行
pool-1-thread-7:24:5
pool-1-thread-3:29:3
pool-1-thread-3:29:4
pool-1-thread-5:28:3
pool-1-thread-6:26:4
pool-1-thread-6:26:5
pool-1-thread-5:28:4
pool-1-thread-5:28:5
pool-1-thread-3:29:5
失敗了

然后注釋這部分代碼

if (index % 5 == 0) {
    return 0;
}

再次運(yùn)行:

//省略若干行
pool-1-thread-7:24:4
pool-1-thread-7:24:5
pool-1-thread-1:26:5
pool-1-thread-8:25:4
pool-1-thread-8:25:5
pool-1-thread-3:29:4
pool-1-thread-3:29:5
全部成功了,計數(shù):150
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末主卫,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子鹃愤,更是在濱河造成了極大的恐慌簇搅,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,376評論 6 491
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件软吐,死亡現(xiàn)場離奇詭異瘩将,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,126評論 2 385
  • 文/潘曉璐 我一進(jìn)店門姿现,熙熙樓的掌柜王于貴愁眉苦臉地迎上來肠仪,“玉大人,你說我怎么就攤上這事建钥√僭希” “怎么了?”我有些...
    開封第一講書人閱讀 156,966評論 0 347
  • 文/不壞的土叔 我叫張陵熊经,是天一觀的道長泽艘。 經(jīng)常有香客問我,道長镐依,這世上最難降的妖魔是什么匹涮? 我笑而不...
    開封第一講書人閱讀 56,432評論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮槐壳,結(jié)果婚禮上然低,老公的妹妹穿的比我還像新娘。我一直安慰自己务唐,他們只是感情好雳攘,可當(dāng)我...
    茶點故事閱讀 65,519評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著枫笛,像睡著了一般吨灭。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上刑巧,一...
    開封第一講書人閱讀 49,792評論 1 290
  • 那天喧兄,我揣著相機(jī)與錄音,去河邊找鬼啊楚。 笑死吠冤,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的恭理。 我是一名探鬼主播拯辙,決...
    沈念sama閱讀 38,933評論 3 406
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼颜价!你這毒婦竟也來了薄风?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,701評論 0 266
  • 序言:老撾萬榮一對情侶失蹤拍嵌,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后循诉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體横辆,經(jīng)...
    沈念sama閱讀 44,143評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,488評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了狈蚤。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片困肩。...
    茶點故事閱讀 38,626評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖脆侮,靈堂內(nèi)的尸體忽然破棺而出锌畸,到底是詐尸還是另有隱情,我是刑警寧澤靖避,帶...
    沈念sama閱讀 34,292評論 4 329
  • 正文 年R本政府宣布潭枣,位于F島的核電站,受9級特大地震影響幻捏,放射性物質(zhì)發(fā)生泄漏盆犁。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 39,896評論 3 313
  • 文/蒙蒙 一篡九、第九天 我趴在偏房一處隱蔽的房頂上張望谐岁。 院中可真熱鬧悼嫉,春花似錦糙俗、人聲如沸讹弯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,742評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽铣墨。三九已至换途,卻和暖如春咬荷,著一層夾襖步出監(jiān)牢的瞬間路呜,已是汗流浹背迷捧。 一陣腳步聲響...
    開封第一講書人閱讀 31,977評論 1 265
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留胀葱,地道東北人漠秋。 一個月前我還...
    沈念sama閱讀 46,324評論 2 360
  • 正文 我出身青樓,卻偏偏與公主長得像抵屿,于是被迫代替她去往敵國和親庆锦。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,494評論 2 348

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