多线程模式之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. 支持阻塞操作和轮询操作的globalfifo设备驱动代码分析以及测试代码

    #include <linux/module.h> #include <linux/types.h> #include <linux/fs.h> #include ...

  2. testlink的下载地址

    http://sourceforge.jp/projects/sfnet_testlink/downloads/TestLink%201.9/TestLink%201.9.12/testlink-1. ...

  3. Python 中模块间全局变量的使用上的注意

    最近用Python写代码,需要用到模块间的全局变量. 网上四处搜索,发现普遍做法是把全局变量放到一个独立的模块中,使用时,导入此全局变量模块即可. 但是在实际使用过程中发现了些小问题:在使用如下代码导 ...

  4. 【原创】一起学C++ 之enum ---------C++ primer plus(第6版)

    枚举 定义:在默认情况下讲整数值赋给枚举量,第一个枚举量的值为0,第二个枚举量的值为1,依次+1 一.定义一个枚举,枚举类型,枚举量 *与C#相比个人认为C++的enum不好一点是不能通过枚举名点其中 ...

  5. windows下常用快捷键

    windows下常用快捷键: 显示桌面: win徽标+D 打开资源管理器: win徽标+E 打开任务管理器: Ctrl+Alt+delete 任务切换: Alt+Tab 应用程序中窗口之间的切换: C ...

  6. oracle----复制表中的数据

    两种方法: 1. 在创建表的时候将数据从其他表中复制过来(并且表的结构也复制过来): 语法: CREATE TABLE table_name AS SELECT column1,......|* FR ...

  7. 分别取商和余数:divmod(a, b)

    使用函数:divmod(a, b)可以实现分别取商和余数的操作: >>> divmod(123,3) (41, 0) >>> divmod(200,6) (33, ...

  8. [转载]C#中获取时间戳(UnixTime)的方法

    .Net中没有封装获取时间戳(UnixTime,相对于1970年1月1日凌晨的毫秒数)的方法.因此本人写了如下方法实现. 提醒在摸索中的朋友,注意方法中的四舍五入.关于讨论四舍五入的方法,可以在这里找 ...

  9. 关于Jquery中ajax方法data参数用法的总结

    data 发送到服务器的数据.将自动转换为请求字符串格式.GET 请求中将附加在 URL 后.查看 processData 选项说明以禁止此自动转换.必须为 Key/Value 格式.如果为数组,jQ ...

  10. .NET(C#):灵活运用CryptoStream,加密不是必须用CryptoStreamMode.Write

    首先.NET中的ICryptoTransform是单向的,也就是只能从一个状态将数据转化成另一个状态,反之是不可以的.当然手动 操作ICryptoTransform还是比较繁琐的,通过CryptoSt ...