并發(fā)模型

Master-Worker 模式

Task.class

public class Task {

    private int id;

    private String name;

    private int price;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public int getPrice() {
        return price;
    }

    public void setPrice(int price) {
        this.price = price;
    }
}

Master.class

public class Master {

    // 1. 應(yīng)該有一個承載任務(wù)的集合
    private ConcurrentLinkedQueue<Task> workQueue = new ConcurrentLinkedQueue<>();

    // 2. 使用 HashMap 去承載所有的 worker 對象
    private HashMap<String, Thread> works = new HashMap<>();

    // 3. 使用一個容器承載每一個 worker 并發(fā)執(zhí)行任務(wù)的結(jié)果集
    private ConcurrentHashMap<String, Object> resultMap = new ConcurrentHashMap<>();

    // 4. 構(gòu)造方法
    public Master(Worker worker, int workerCount) {
        // 每一個 worker 對象都需要有 Master 的引用图仓,workQueue 用于任務(wù)的領(lǐng)取,resultMap 用于任務(wù)的提交
        worker.setWorkQueue(this.workQueue);
        worker.setResultMap(this.resultMap);
        for (int i = 0; i < workerCount; i++) {
            // key 表示每一個 worker 的名字,value 表示線程執(zhí)行對象
            works.put("子節(jié)點(diǎn)" + Integer.toString(i), new Thread(worker));
        }
    }

    // 5. 提交方法
    public void submit(Task task) {
        this.workQueue.add(task);
    }

    // 6. 需要有一個執(zhí)行的方法(啟動應(yīng)用程序 讓所有的 worker 工作)
    public void execute() {
        for (Map.Entry<String, Thread> me : works.entrySet()) {
            me.getValue().start();
        }
    }


    // 7. 判斷線程是否執(zhí)行完畢
    public boolean isComplete() {
        for (Map.Entry<String, Thread> me : works.entrySet()) {
            if (me.getValue().getState() != Thread.State.TERMINATED) {
                return false;
            }
        }
        return true;
    }

    // 8. 返回結(jié)果集數(shù)據(jù)
    public Long getResult() {
        Long ret = 0L;
        for (Map.Entry<String, Object> me : resultMap.entrySet()) {
            Integer value = (Integer) me.getValue();
            ret += value;
        }
        return ret;
    }
}

Worker.class

public class Worker implements Runnable {
    private ConcurrentLinkedQueue<Task> workQueue;
    private ConcurrentHashMap<String, Object> resultMap;

    public void setWorkQueue(ConcurrentLinkedQueue<Task> workQueue) {
        this.workQueue = workQueue;
    }

    public void setResultMap(ConcurrentHashMap<String, Object> resultMap) {
        this.resultMap = resultMap;
    }

    @Override
    public void run() {
        while (true) {
            Task input = this.workQueue.poll();
            if (input == null) {
                break;
            }
            // 真正的去做業(yè)務(wù)處理
            Object output = handle(input);

            this.resultMap.put(Integer.toString(input.getId()), output);
        }
    }

    public Object handle(Task input) {
        return null;
    }

}

MyWorker.class

public class MyWorker extends Worker {

    public Object handle(Task input) {
        Object output = null;
        try {
            // 表示處理 task 任務(wù)的耗時,可能是做數(shù)據(jù)的加工戈次,也可能是操作數(shù)據(jù)庫...
            Thread.sleep(5000);

            output = input.getPrice();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        return output;
    }
}

Main.class

public class Main {

    public static void main(String[] args) {
        Master master = new Master(new MyWorker(), Runtime.getRuntime().availableProcessors());
        System.out.println("機(jī)器線程數(shù)量:" + Runtime.getRuntime().availableProcessors());

        Random random = new Random();
        for (int i = 1; i <= 100; i++) {
            Task task = new Task();
            task.setId(i);
            task.setName("任務(wù)" + i);
            task.setPrice(random.nextInt(1000));
            master.submit(task);
        }
        master.execute();

        long start = System.currentTimeMillis();
        while (true) {
            if (master.isComplete()) {
                long end = System.currentTimeMillis() - start;
                Long ret = master.getResult();
                System.out.println("最終結(jié)果:" + ret + "蔑歌,耗時:" + end);
                break;
            }
        }

    }
}

并發(fā)模型(一)——Future模式

并發(fā)模型(二)——Master-Worker模式

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末碌上,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子丘逸,更是在濱河造成了極大的恐慌单鹿,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,198評論 6 514
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件深纲,死亡現(xiàn)場離奇詭異仲锄,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)湃鹊,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,334評論 3 398
  • 文/潘曉璐 我一進(jìn)店門儒喊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人币呵,你說我怎么就攤上這事怀愧。” “怎么了余赢?”我有些...
    開封第一講書人閱讀 167,643評論 0 360
  • 文/不壞的土叔 我叫張陵芯义,是天一觀的道長。 經(jīng)常有香客問我妻柒,道長扛拨,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 59,495評論 1 296
  • 正文 為了忘掉前任举塔,我火速辦了婚禮绑警,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘啤贩。我一直安慰自己待秃,他們只是感情好拜秧,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,502評論 6 397
  • 文/花漫 我一把揭開白布痹屹。 她就那樣靜靜地躺著,像睡著了一般枉氮。 火紅的嫁衣襯著肌膚如雪志衍。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,156評論 1 308
  • 那天聊替,我揣著相機(jī)與錄音楼肪,去河邊找鬼。 笑死惹悄,一個胖子當(dāng)著我的面吹牛春叫,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 40,743評論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼暂殖,長吁一口氣:“原來是場噩夢啊……” “哼价匠!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起呛每,我...
    開封第一講書人閱讀 39,659評論 0 276
  • 序言:老撾萬榮一對情侶失蹤踩窖,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后晨横,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體洋腮,經(jīng)...
    沈念sama閱讀 46,200評論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,282評論 3 340
  • 正文 我和宋清朗相戀三年手形,在試婚紗的時候發(fā)現(xiàn)自己被綠了啥供。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,424評論 1 352
  • 序言:一個原本活蹦亂跳的男人離奇死亡库糠,死狀恐怖滤灯,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情曼玩,我是刑警寧澤鳞骤,帶...
    沈念sama閱讀 36,107評論 5 349
  • 正文 年R本政府宣布,位于F島的核電站黍判,受9級特大地震影響豫尽,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜顷帖,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,789評論 3 333
  • 文/蒙蒙 一美旧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧贬墩,春花似錦榴嗅、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,264評論 0 23
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至肿孵,卻和暖如春唠粥,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背停做。 一陣腳步聲響...
    開封第一講書人閱讀 33,390評論 1 271
  • 我被黑心中介騙來泰國打工晤愧, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人蛉腌。 一個月前我還...
    沈念sama閱讀 48,798評論 3 376
  • 正文 我出身青樓官份,卻偏偏與公主長得像只厘,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子舅巷,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,435評論 2 359

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

  • 本系列譯自jakob jenkov的Java并發(fā)多線程教程(本章節(jié)部分內(nèi)容參考http://ifeve.c...
    Steven_cao閱讀 984評論 1 10
  • 在創(chuàng)建Storm的Topology時懈凹,我們通常使用如下代碼:builder.setBolt("cpp",new C...
    wangliang938閱讀 1,947評論 1 1
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)悄谐,斷路器介评,智...
    卡卡羅2017閱讀 134,693評論 18 139
  • 一個人的尖酸刻薄,大概是從前沒有人愿意傾聽爬舰,無人理解们陆。最后的尖酸刻薄,統(tǒng)稱為情屹,孤獨(dú)坪仇。
    半塊青金石閱讀 188評論 0 0
  • 董事長兼總經(jīng)理 唐曾琦(公司創(chuàng)始人,負(fù)責(zé)營銷垃你、項目執(zhí)行和技術(shù)研發(fā))副總經(jīng)理兼董事會秘書 湯岳沙(公司創(chuàng)始人 負(fù)責(zé)...
    raymin閱讀 526評論 0 0