多线程模式之MasterWorker模式

Master-Worker模式的核心思想是,系统由两类进程协作工作:Master进程和Worker进程。Master进程负责接收和分配任务,Worker进程负责处理子任务。当Worker进程将各个子任务处理完成后,将结果返回给Master进程,由Master进程做归纳和汇总。

工作示意图如下图所示:









它的优势在于将一个大的任务分解成一个个的子任务并行执行,提高程序执行效率。

代码示例:



Master进程类:

public class Master {

    protected Queue<Object> workQueue = new ConcurrentLinkedQueue<Object>();//存放子任务

    protected Map<String,Thread> threadMap = new HashMap<String,Thread>();//存放Worker线程

    protected Map<String,Object> resultMap = new ConcurrentHashMap<String, Object>();//存放返回结果集

    public boolean isCompleted(){

        for(Map.Entry<String,Thread> entry:threadMap.entrySet()){

            if(entry.getValue().getState() != Thread.State.TERMINATED){

                return false;

            }

        }

        return true;

    }

    public Master(Worker worker,int countWorker){

        worker.setWorkQueue(workQueue);

        worker.setResultMap(resultMap);

        for(int i=0;i<countWorker;i++){//创建多个Worker线程

            threadMap.put(Integer.toString(i),new Thread(worker,Integer.toString(i)));

        }

    }

    public void submit(Object job){

        workQueue.add(job);//将任务加到子任务队列中

    }

    public Map<String,Object> getResultMap(){

        return resultMap;

    }

    public void execute(){

//循环启动Worker线程

        for(Map.Entry<String,Thread> entry:threadMap.entrySet()){

           entry.getValue().start();

        }

    }



}





Worker进程类:



public class Worker implements  Runnable{

    protected Queue<Object> workQueue;

    protected Map<String,Object> resultMap;

    public void setWorkQueue(Queue<Object> workQueue){

        this.workQueue = workQueue;

    }

    public void setResultMap( Map<String,Object> resultMap){

        this.resultMap = resultMap;

    }

    public Object handle(Object input){

        return input;

    }

    public void run(){

        while(true){

            Object input = workQueue.poll();//从子任务中取任务执行

            if(input == null) break;

            Object re = handle(input);//这是一个模板方法模式

            resultMap.put(Integer.toString(input.hashCode()),re);

        }

    }

}





PlusWorker进程类:

public class PlusWorker extends Worker {

    public Object handle(Object input){

        Integer i = (Integer)input;

        return i*i*i;

    }

}



测试类:

public class Main {

    public static void  main(String[] args){

        Master m = new Master(new PlusWorker(),5);

        for(int i=0;i<100;i++)

            m.submit(i);

        m.execute();

        int re = 0;

        Map<String,Object> resultMap = m.getResultMap();

        while(resultMap.size() >0 || !m.isCompleted()){

            Set<String> keys = resultMap.keySet();

            String key = null;

            for(String k:keys){

                key = k;

                break;

            }

            Integer i = null;

            if(key != null)

                i = (Integer)resultMap.get(key);

            if(i != null)

                re += i;

            if(key != null)

                resultMap.remove(key);



        }

        System.out.println("re:"+re);

    }

}





Main不用等所有的Worker线程都计算完以后再执行,只要有计算完成的,它就一直计算。







《Java性能优化》 -葛一鸣

多线程模式之MasterWorker模式的更多相关文章

  1. 并行模式之Master-Worker模式

    并行模式之Master-Worker模式 一).Master-Worker模式 作用: 将一个大任务分解成若干个小任务,分发给多个子线程执行. 注: 将大任务分解成小任务,小任务的实现逻辑要相同. 二 ...

  2. 多线程集成设计模式--MasterWorker模式讲解(一)

    Master-Worker模式是常用的并行模式之一,它的核心思想是,系统有两个进程协作工作:Master进程,负责接收和分配任务:Worker进程,负责处理子任务.当Worker进程将子任务处理完成后 ...

  3. 多线程的设计模式--Future模式,Master-Worker模式,生产者-消费者模式

    代码示例: public interface Data { String getRequest(); } public class FutureData implements Data{ privat ...

  4. Java多线程编程中Future模式的详解

    Java多线程编程中,常用的多线程设计模式包括:Future模式.Master-Worker模式.Guarded Suspeionsion模式.不变模式和生产者-消费者模式等.这篇文章主要讲述Futu ...

  5. 并行设计模式(二)-- Master-Worker模式

    Java多线程编程中,常用的多线程设计模式包括:Future模式.Master-Worker模式.Guarded Suspeionsion模式.不变模式和生产者-消费者模式等.这篇文章主要讲述Mast ...

  6. 深入理解[Master-Worker模式]原理与技术

    Master-Worker模式是常用的并行模式之一.它的核心思想是,系统由两类进程协作工作:Master进程和Worker进程.Master进程负责接收和分配任务,Worker进程负责处理子任务.当各 ...

  7. Java多线程编程中Future模式的详解<转>

    Java多线程编程中,常用的多线程设计模式包括:Future模式.Master-Worker模式.Guarded Suspeionsion模式.不变模式和生产者-消费者模式等.这篇文章主要讲述Futu ...

  8. Java多线程Master-Worker模式

    Java多线程Master-Worker模式,多适用于需要大量重复工作的场景中. 例如:使用Master-Worker计算0到100所有数字的立方的和 1.Master接收到100个任务,每个任务需要 ...

  9. 14.多线程设计模式 - Master-Worker模式

    多线程设计模式 - Master-Worker模式 并发设计模式属于设计优化的一部分,它对于一些常用的多线程结构的总结和抽象.与串行相比并行程序结构通常较为复杂,因此合理的使用并行模式在多线程并发中更 ...

随机推荐

  1. webApi实现增删改查操作

    1.WebApi是什么 ASP.NET Web API 是一种框架,用于轻松构建可以由多种客户端(包括浏览器和移动设备)访问的 HTTP 服务.ASP.NET Web API 是一种用于在 .NET ...

  2. rsync与inotify 数据同步

    发布:thebaby   来源:脚本学堂     [大 中 小] 本文介绍下,在linux系统中,使用rsync与inotify实现数据同步的一个实例,有研究文件同步的朋友可以作个参考.本文转自:ht ...

  3. KISSY学习笔记(更新中)

    序:身为一个JAVA开发工程师,前端代码我尽量是使用原生的JS来写的,或是使用一些JQ的开源组件(但是也只是使用,没有好好去研究过JQ这个框架).目前由于工作需要,必须要使用KISSY,打算借此机会, ...

  4. WPF学习笔记2——XAML之2

    三.事件处理程序与代码隐藏 例如,为一个Page添加一个Button控件,并为该Button添加事件名称Button_Click: <Page xmlns="http://schema ...

  5. MVC5添加控制器总是报“Multiple object sets per type are not supported”

    http://www.asp.net/mvc/tutorials/mvc-5/introduction/creating-a-connection-string 按照上面的指导做练习,  总报小面的错 ...

  6. JDBC和DBUtils区别(查询时jdbc只能返回ResultSet需要po转vo,dbutils返回的BeanListHandler与BeanHandler对应集合与对象)

    17:34 2013/6/7 JDBC //添加客户 public void addNewCustomer(Customer c) throws DAOException { Connection c ...

  7. Pair Project: Elevator Scheduler [电梯调度算法的实现和测试]:刘耀先-11061183,罗凡-11061174

    本次为我们两个人的第一次结对编程.从总体而言,我们对结对编程比单人编程略显不适应.但是经过一段时间的磨合,我们逐渐的习惯了这种编程方式. 1.  结对编程的优缺点 结对编程的优点: (1)       ...

  8. 《有限元分析基础教程》(曾攀)笔记一-二维杆单元有限元程序(基于Python)

    曾攀老师的<有限元分析基础教程>第三章有二维杆单元的推导,并结合一个例题进行了解析解和基于Matlab的程序求解.但是我感觉书中的MATLAB代码有点罗嗦,而且一些实现方法也比较麻烦,比如 ...

  9. ECSHOP安装或使用中提示Strict Standards: Non-static method cls_image:

    随着ECSHOP的不断发展,越来越多的人成为了ECSHOP的忠实粉丝.由于每个人的服务器环境和配置都不完全相同,所以ECSHOP也接二连三的爆出了各种各样的错误信息.相信不少新手朋友在ECSHOP安装 ...

  10. COOKIE漫谈

    cookie概述在上一节,曾经利用一个不变的框架来存储购物栏数据,而商品显示页面是不断变化的,尽管这样能达到一个模拟全局变量的功能,但并不严谨.例如在导航框架页面内右击,单击快捷菜单中的[刷新]命令, ...