设计模式之多线程分工模式---Worker Thread模式

2024-01-16 11:36

本文主要是介绍设计模式之多线程分工模式---Worker Thread模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

系列文章目录

设计模式之避免共享的设计模式Immutability(不变性)模式
设计模式之并发特定场景下的设计模式 Two-phase Termination(两阶段终止)模式
设计模式之避免共享的设计模式Copy-on-Write模式
设计模式之避免共享的设计模式 Thread-Specific Storage 模式
设计模式之多线程版本的if------Guarded Suspension模式
设计模式之多线程版本的if------Balking模式
设计模式之多线程分工模式— Thread-Per-Message模式


文章目录

  • 系列文章目录
  • 简述
  • 应用场景
    • 例子
  • 总结


简述

  • 要想有效避免线程的频繁创建、销毁以及 OOM 问题,就不得不提 Java 领域使用最多的Worker Thread 模式。

Worker Thread 模式可以类比为工厂中的生产线。在工厂中,存在多个工人负责不同的工作,每个工人专注于自己的工作,通过协作来完成整个产品的生产过程。类似地,Worker Thread 模式也包括了多个工作线程,每个线程负责处理不同的任务,并通过协作来完成整个系统的工作。这种模式有助于提高系统的并发性能和效率,类似于工厂中的生产线可以提高产品的生产效率一样。

应用场景

  1. 服务器端应用程序:在服务器端应用中,通常需要处理大量的并发请求,Worker Thread模式可用于处理这些请求,每个工作线程负责处理一个请求,从而提高服务器的并发处理能力。

  2. 多任务处理:在需要并行处理多个任务的情况下,可以使用Worker Thread 模式来实现并发执行,提高任务处理效率。

  3. 数据处理和计算:例如批量数据处理、大规模数据计算等场景,可以使用Worker Thread 模式来并行处理数据,加快处理速度。

  4. 消息处理系统:在需要异步处理消息的系统中,如消息队列系统、事件驱动系统等,可以使用Worker Thread 模式来处理消息,实现异步处理和并发执行消息中的逻辑。

  5. GUI 应用程序:在构建GUI应用程序中,可以将一些耗时的任务放到工作线程中进行处理,以保持主线程的响应性。

例子

仅供参考

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.net.ServerSocket;
import java.net.Socket;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;/*** @author yang* @version 1.0.0*/
public class WorkerThreadServer {public static void main(String[] args) {ExecutorService executor = Executors.newFixedThreadPool(5);try (ServerSocket server = new ServerSocket(8888)) {System.out.println("Server started. Listening for incoming connections...");while (true) {Socket client = server.accept();executor.execute(new ClientHandler(client));}} catch (IOException e) {e.printStackTrace();} finally {executor.shutdown();}}static class ClientHandler implements Runnable {private final Socket clientSocket;public ClientHandler(Socket socket) {this.clientSocket = socket;}@Overridepublic void run() {try {System.out.println("Connected to client: " + clientSocket.getInetAddress());// 处理客户端请求逻辑BufferedReader in = new BufferedReader(new InputStreamReader(clientSocket.getInputStream()));PrintWriter out = new PrintWriter(clientSocket.getOutputStream(), true);String message = in.readLine();System.out.println("Received message from client: " + message);// 模拟处理请求Thread.sleep(1000);// 发送响应给客户端out.println("Message received successfully");} catch (IOException | InterruptedException e) {e.printStackTrace();} finally {try {clientSocket.close();} catch (IOException e) {e.printStackTrace();}}}}
}

我们创建了一个WorkerThreadServer类作为服务器端,通过ServerSocket监听8888端口的连接请求。当有新的连接请求时,服务器端会创建一个新的ClientHandler工作线程来处理客户端请求。每个ClientHandler线程负责处理一个客户端连接请求的逻辑,之后响应给客户端,并关闭连接。

需要注意的是,实际的生产环境中可能需要更多的错误处理、资源管理、安全性措施等,这里为了简化示例未添加。


总结

  • Worker Thread 模式需要注意死锁问题,提交的任务之间不要有依赖性。
  • Worker Thread模式适用于需要并发处理多个任务提高系统吞吐量和效率的场景。通过合理地使用工作线程来处理任务,可以提高系统的并发性能和响应速度。

这篇关于设计模式之多线程分工模式---Worker Thread模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/612457

相关文章

浅析Rust多线程中如何安全的使用变量

《浅析Rust多线程中如何安全的使用变量》这篇文章主要为大家详细介绍了Rust如何在线程的闭包中安全的使用变量,包括共享变量和修改变量,文中的示例代码讲解详细,有需要的小伙伴可以参考下... 目录1. 向线程传递变量2. 多线程共享变量引用3. 多线程中修改变量4. 总结在Rust语言中,一个既引人入胜又可

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

Thread如何划分为Warp?

1 .Thread如何划分为Warp? https://jielahou.com/code/cuda/thread-to-warp.html  Thread Index和Thread ID之间有什么关系呢?(线程架构参考这里:CUDA C++ Programming Guide (nvidia.com)open in new window) 1维的Thread Index,其Thread

多线程解析报表

假如有这样一个需求,当我们需要解析一个Excel里多个sheet的数据时,可以考虑使用多线程,每个线程解析一个sheet里的数据,等到所有的sheet都解析完之后,程序需要提示解析完成。 Way1 join import java.time.LocalTime;public class Main {public static void main(String[] args) thro

模版方法模式template method

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/template-method 超类中定义了一个算法的框架, 允许子类在不修改结构的情况下重写算法的特定步骤。 上层接口有默认实现的方法和子类需要自己实现的方法

【iOS】MVC模式

MVC模式 MVC模式MVC模式demo MVC模式 MVC模式全称为model(模型)view(视图)controller(控制器),他分为三个不同的层分别负责不同的职责。 View:该层用于存放视图,该层中我们可以对页面及控件进行布局。Model:模型一般都拥有很好的可复用性,在该层中,我们可以统一管理一些数据。Controlller:该层充当一个CPU的功能,即该应用程序

迭代器模式iterator

学习笔记,原文链接 https://refactoringguru.cn/design-patterns/iterator 不暴露集合底层表现形式 (列表、 栈和树等) 的情况下遍历集合中所有的元素

《x86汇编语言:从实模式到保护模式》视频来了

《x86汇编语言:从实模式到保护模式》视频来了 很多朋友留言,说我的专栏《x86汇编语言:从实模式到保护模式》写得很详细,还有的朋友希望我能写得更细,最好是覆盖全书的所有章节。 毕竟我不是作者,只有作者的解读才是最权威的。 当初我学习这本书的时候,只能靠自己摸索,网上搜不到什么好资源。 如果你正在学这本书或者汇编语言,那你有福气了。 本书作者李忠老师,以此书为蓝本,录制了全套视频。 试

利用命令模式构建高效的手游后端架构

在现代手游开发中,后端架构的设计对于支持高并发、快速迭代和复杂游戏逻辑至关重要。命令模式作为一种行为设计模式,可以有效地解耦请求的发起者与接收者,提升系统的可维护性和扩展性。本文将深入探讨如何利用命令模式构建一个强大且灵活的手游后端架构。 1. 命令模式的概念与优势 命令模式通过将请求封装为对象,使得请求的发起者和接收者之间的耦合度降低。这种模式的主要优势包括: 解耦请求发起者与处理者

Java 多线程概述

多线程技术概述   1.线程与进程 进程:内存中运行的应用程序,每个进程都拥有一个独立的内存空间。线程:是进程中的一个执行路径,共享一个内存空间,线程之间可以自由切换、并发执行,一个进程最少有一个线程,线程实际数是在进程基础之上的进一步划分,一个进程启动之后,进程之中的若干执行路径又可以划分成若干个线程 2.线程的调度 分时调度:所有线程轮流使用CPU的使用权,平均分配时间抢占式调度