Java JUC工具类--Master-Worker

Master-Worker

  • Master-Worker模式是常用的并行计算模式。它的核心思想是系统由两类进程协作工作:Master进程和Worker进程
  • Master负责接收和分配任务,Worker负责处理子任务
  • 当各个Worker子进程处理完成后,会将结果返回给Master,由Master做归纳和总结。 其好处是能将一个大任务分解成若干个小任务并行执行,从而提高系统的吞吐量
  • master接收来自client的任务请求,将任务分发给不同的worker任务节点去执行任务,再将最终的任务结果返回给客户端

  • 模拟如下:客户端、Master和Worker
  • master里面用ConcurrentLinkedQueue盛放待处理的任务和HashMap<string,Thread>盛放每个线程,以及将每一个worker的执行结果存放在ConcurrentHashMap 中
  • worker需要对任务队列和线程处理进行映射,并且实现Runnable接口,设立一个集合,存放任务处理完的结果,等处理完之后,将结果集合返还到master的ConcurrentHashMap中,再由Master将结果返回到客户端

具体代码如下

  • Task.java
package com.example.core.masterworker;public class Task {private int id;private int count;public Task(){}public Task(int id,int count){this.id = id;this.count = count;}public int getId() {return id;}public void setId(int id) {this.id = id;}public int getCount() {return count;}public void setCount(int count) {this.count = count;}
}
  • Master.java
package com.example.core.masterworker;import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentLinkedQueue;public class Master {//1 承装任务的一个容器private ConcurrentLinkedQueue<Task> taskQueue = new ConcurrentLinkedQueue<>();//2 承装worker执行器private HashMap<String,Thread>workers = new HashMap<>();//3 接受worker处理成功的结果集合private ConcurrentHashMap<String,Object>resultMap = new ConcurrentHashMap<>();//4 构造方法里面,要对worker进行一个初始化操作public Master(Worker worker,int workerCount) {//4.1 每一个worker 应该有master任务队列容器对引用worker.setTaskQueue(this.taskQueue);//4.2 每一个worker 应该有master结果集容器对的引用worker.setResultMap(this.resultMap);//4.3 将所有的worker进行初始化,放入workers容器中for(int i=0;i<workerCount;i++){this.workers.put(Integer.toString(i),new Thread(worker));}}//5 需要一个提交任务的方法public void submit(Task task){this.taskQueue.add(task);}//6 需要一个真正Master所有worker进行工作的方法public void execute(){for(Map.Entry<String,Thread>me:this.workers.entrySet()){me.getValue().start();}}//7 需要一个统计的方法,用于合并结果结合public int getResult(){int sum=0;for(Map.Entry<String,Object>me : resultMap.entrySet()){sum += (Integer)me.getValue();}return sum;}//8,判断是否所有的worker都完成了工作,如果全部完成就返truepublic boolean isComplete(){for(Map.Entry<String,Thread> me : this.workers.entrySet()){if(me.getValue().getState() != Thread.State.TERMINATED){return false;}}return true;}
}
  • worker.java
package com.example.core.masterworker;import java.util.Random;
import java.util.concurrent.ConcurrentHashMap;
import java.util.concurrent.ConcurrentLinkedQueue;public class Worker implements Runnable{private ConcurrentLinkedQueue<Task> taskQueue;private ConcurrentHashMap<String,Object> resultMap;//设置任务集合public void setTaskQueue(ConcurrentLinkedQueue<Task>taskQueue){this.taskQueue = taskQueue;}//设置结果集合public void setResultMap(ConcurrentHashMap<String,Object>resultMap){this.resultMap = resultMap;}@Overridepublic void run(){while(true){Task task = this.taskQueue.poll();if(task == null){break;}try{Object result = handle(task);this.resultMap.put(Integer.toString(task.getId()),result);}catch(Exception e){e.printStackTrace();}}}private Random r = new Random();//实际做每一个工作private Object handle(Task task)throws Exception{//每一个任务的处理时间Thread.sleep(200);int ret = task.getCount();return ret;}
}
  • Main.java
package com.example.core.masterworker;import java.util.Random;public class Main {public static void main(String[] args) {System.out.println("线程数:"+Runtime.getRuntime().availableProcessors());Master master = new Master(new Worker(),Runtime.getRuntime().availableProcessors());Random r = new Random();for(int i=0;i<100;i++){Task t = new Task(i,r.nextInt(1000));master.submit(t);}master.execute();long start = System.currentTimeMillis();while(true){if(master.isComplete()){long end = System.currentTimeMillis();int result = master.getResult();System.out.println("最终结果为:"+result+",总耗时:"+(end-start));break;}}}
}
/*
output:
线程数:12
最终结果为:48834,总耗时:1819*/

 

 

 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/447294.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

身体打来的电话,你一定要接!

心脏有问题时。左边手臂会酸、麻、痛。肝脏有问题时。小腿晚上睡觉时容易抽筋。肾脏出现问题时。声音就会出不来&#xff0c;就会沙哑。脾胃出现问题时。偏头痛。附&#xff1a;五脏排毒最简单有效的方法 一、心脏有问题时 1。呼吸会不顺畅&#xff0c;胸口会闷也会刺痛&…

Java JUC工具类--Semaphore

Semaphore 在Semaphore信号量非常适合高并发访问限制&#xff0c;新系统在上线之前&#xff0c;要对系统的访问量进行评估&#xff0c;评估是经过以往的经验、数据、历年的访问量&#xff0c;已经推广力度进行一个合理的评估当然评估标准不能太大也不能太小&#xff0c;太大的…

python 基础知识点整理 和具体应用

Python教程 Python是一种简单易学&#xff0c;功能强大的编程语言。它包括了高效的高级数据结构和简单而有效的方法&#xff0c;面向对象编程。Python优雅的语法&#xff0c;动态类型&#xff0c;以及它天然的解释能力&#xff0c;使其成为理想的语言&#xff0c;脚本和应用程序…

Java 线程池相关问题

线程池的拒绝策略 AbortPolicy&#xff1a;直接抛出异常阻止系统正常工作。CallerRunsPolicy&#xff1a;只要线程池未关闭&#xff0c;该策略直接在调用者线程中&#xff0c;运行当前被丢弃的任务。DiscardOldestPolicy&#xff1a;丢弃最老的一个请求&#xff0c;尝试再次提…

对编程人员我想说:多做 多实践 多写代码

有很多人问我&#xff0c;怎样提高自己的能力&#xff1f;有初学者&#xff0c;有水平达到一定程度的程序员。 我想说&#xff0c;不要过多的看代码&#xff0c;看计算机理论&#xff0c;看别人写的文章&#xff0c;代码等&#xff0c;最重要的是自己理解了某个原理&#xff0c…

读人是基础,看人是关键,做人最重要

人生在世&#xff0c;读人是基础&#xff0c;看人是关键&#xff0c;做人最重要。 一、读人——一个人就是一本书。读人&#xff0c;比读其他文字的书更难。在生活中&#xff0c;每个人都是书&#xff0c;每人又都是读者。我们认认真真地读&#xff0c;读了大半辈子&#xff0c…

使用postman模拟百度通用文字识别

1&#xff0c;登录百度AI开放平台 百度AI网站新手指南链接在顶部导航栏中&#xff0c;找到控制台选项&#xff0c;输入账号和密码&#xff0c;进入管理中心页面在管理中心页面中&#xff0c;找到文字识别的选项找到创建应用的选项&#xff0c;进行ocr项目的创建需要输入应用的…

3个观念 不再瞎学习!

此刻&#xff0c;你应该要做什么准备&#xff1f;加码股市还是追逐房市&#xff1f;都不是。在你分配时间、资源的投资组合里&#xff0c;有没有这一项&#xff1a;“自己”&#xff1f; 没有人会否认充实自我的重要&#xff0c;但是经历一场金融风暴大震撼&#xff0c;当企业…

Java调用百度OCR文字识别的接口

调用百度OCR文字识别的接口&#xff0c;来自于百度官网&#xff0c;亲测可以使用 跳转链接FileUtil的下载链接Base64Util下载链接HttpUtil下载链接GsonUtils下载链接Accurate.java文件 package com.baidu.ai.aip;import com.baidu.ai.aip.utils.Base64Util; import com.baidu.…

做好7步 迅速成为行业专家

行行出状元&#xff0c;但不一定人人能成为行业专家或权威。无论是做独立顾问&#xff0c;还是手下有250名员工的工厂主管&#xff0c;都是在用自己多年丰富经验在帮助企业成功。既然有了专业知识和经验&#xff0c;为什么不把它最大化利用&#xff0c;来建立自己的行业权威&am…

redis常用命令与特性

keys * 返回满足条件的所有key&#xff0c;可以模糊匹配select 数字0-15&#xff0c;进行数据库切换&#xff0c;默认0-15个exists 是否存在指定的keypersist 取消过期时间 select 选择数据库 &#xff08;0-15&#xff0c;总共16个数据库&#xff09;move key index 将当前数据…

紧急不代表重要:管理时间的六个秘密

当整个世界都永远在跟集中精神做事做对的时候&#xff0c;怎么办&#xff1f;Managershare&#xff1a;“世界上效率最高的程序员有什么相同之处&#xff1f;不是经验&#xff0c;薪水或者花在一个项目上的时间&#xff0c;而是他们的老板创造了一个免于走神的环境。”这老板太…

redis安全

定期打补丁禁止一些高危命令 &#xff08;flushdb、keys *、flushall&#xff09;以低权限运行 Redis 服务禁止外网访问 Redis设置访问密码 足够复杂&#xff0c;防止暴力破解 requirepass xxxxxxxx访问权限 内网通过acl限制可以访问redis的ip和端口

如何在三个月内获得三年的工作经验

在多年的工作生涯中&#xff0c;总会目睹一批人的升职像火箭速度一样。 而总有一批人&#xff0c;就像蜗牛一样&#xff0c;工作岗位和职位几乎从来不变。 我们看看&#xff0c;2个名人的快速成长史。 一个是教英语的李阳&#xff0c;他读大学时成绩不好&#xff0c;英语不…

Redis Cluster集群模式

Redis Cluster 它是Redis的分布式解决方案&#xff0c;在Redis 3.0版本正式推出的&#xff0c;有效解决了Redis分布式方面的需求。当遇到单机内存、并发、流量等瓶颈时&#xff0c;可以采用Cluster架构达到负载均衡的目的。数据分布理论: 分布式数据库首要解决把整个数据集按照…

永远和靠谱的人在一起!

巴菲特每年都会同大学生进行座谈&#xff0c;在一次交流会上&#xff0c;有学生问他&#xff1a;您认为一个人最重要的品质是什么?巴菲特没有正面回答这个问题&#xff0c;而是讲了一个小游戏&#xff0c;名为&#xff1a;买进你同学的10%。 巴菲特说&#xff1a;现在给你们一…

Redis事务详解

传统事务的特性 原子性一致性隔离性&#xff1a;事务之间互不干扰持久化&#xff1a;一旦事务提交&#xff0c;无法修改 Redis事务机制 MULTI、EXEC、DISCARD和WATCH命令是Redis事务功能的基础。Redis事务允许在一次单独的步骤中执行一组命令&#xff0c;并且可以保证如下两个…

工作的最终目的

当时公司招了大批应届本科和研究生毕业的新新人类。平均年龄25岁。那个新的助理&#xff0c;是经过多次面试后&#xff0c;我亲自招回来的一个女孩。名牌大学本科毕业&#xff0c;聪明&#xff0c;性格活泼。私下里我得承认&#xff0c;我招她的一个很重要的原因&#xff0c;除…

销售员所做的一切工作最终目的就是为了成交

&#xff08;1&#xff09;最后一次报价禁忌.报价过晚或者过于匆忙步幅度太大&#xff0c;显得过于慷慨;让步幅度太小&#xff0c;显得毫无意义当谈判进展到最后&#xff0c;双方只是在最后的某一两个问题上尚有不同意见&#xff0c;过让步才能求得一致&#xff0c;签订协议。在…

Redis java客户端操作

jedis jedis官方指定的redis java客户端&#xff0c;将其导入到pom.xml问价内 <!-- https://mvnrepository.com/artifact/redis.clients/jedis --> <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><vers…