首页 > 其他分享 >rust线程池

rust线程池

时间:2024-07-08 19:08:55浏览次数:9  
标签:thread Worker job 线程 let id rust

#![allow(unused)]
use std::sync::{mpsc, Arc, Mutex};
use std::thread;

// 定义消息类型,可以是新任务或终止信号
enum Message {
    NewJob(Job),
    Terminate,
}

// 定义线程池结构体
pub struct ThreadPool {
    workers: Vec<Worker>,
    // sender: mpsc::Sender<Job>,
    sender: mpsc::Sender<Message>,
}

// 定义任务类型,可以是任何实现了FnOnce trait的闭包
type Job = Box<dyn FnOnce() + Send + 'static>;

impl ThreadPool {
    // 创建线程池,参数为线程数量
    pub fn new(size: usize) -> ThreadPool {
        assert!(size > 0);
        // 创建一个通道,用于发送任务
        let (sender, receiver) = mpsc::channel();
        // 将通道包装成Arc<Mutex>,以便多个线程共享
        let receiver = Arc::new(Mutex::new(receiver));
        let mut workers = Vec::with_capacity(size);
        // 创建指定数量的工作线程
        for id in 0..size {
            workers.push(Worker::new(id, Arc::clone(&receiver)));
        }
        ThreadPool { workers, sender }
    }
    // 执行任务,参数为任务闭包
    pub fn execute<F>(&self, f: F)
    where
        F: FnOnce() + Send + 'static,
    {
        // 将任务包装成Box<dyn FnOnce() + Send + 'static>,并发送到通道
        let job = Box::new(f);
        // self.sender.send(job).unwrap();
        self.sender.send(Message::NewJob(job)).unwrap();
    }
}
// 实现Drop trait,在线程池被销毁时执行清理操作
impl Drop for ThreadPool {
    fn drop(&mut self) {
        // 向每个工作线程发送终止信号
        for _ in &mut self.workers {
            self.sender.send(Message::Terminate).unwrap();
        }
        println!("Shutting down all workers.");
        // 等待每个工作线程结束
        for worker in &mut self.workers {
            println!("Shutting down worker {}", worker.id);
            if let Some(thread) = worker.thread.take() {
                thread.join().unwrap();
            }
        }
    }
}

// 定义工作线程结构体
struct Worker {
    id: usize,
    // thread: thread::JoinHandle<()>,
    thread: Option<thread::JoinHandle<()>>,
}
impl Worker {
    // 创建工作线程,参数为线程ID和通道
    fn new(id: usize, receiver: Arc<Mutex<mpsc::Receiver<Message>>>) -> Worker {
        // 创建一个新线程,循环接收任务并执行
        let thread = thread::spawn(move || loop {
            // let job = receiver.lock().unwrap().recv().unwrap();
            // println!("Worker {} got a job; executing.", id);
            // job();
            // 接收任务
            let message = receiver.lock().unwrap().recv().unwrap();
            // 根据任务类型执行相应操作
            match message {
                Message::NewJob(job) => {
                    println!("Worker {} executing job.", id);
                    job();
                }
                Message::Terminate => {
                    println!("Worker {} terminated.", id);
                    break;
                }
            }
        });
        Worker {
            id,
            thread: Some(thread),
        }
    }
}

 

标签:thread,Worker,job,线程,let,id,rust
From: https://www.cnblogs.com/coclai/p/18290578

相关文章

  • 基于 RedisTemplate + 线程池 实现 Redis分布式锁
    分布式锁需求往往部署的后台服务不会只是单机部署了,而是通过集群的方式运行在两个甚至多个部署的服务器上(即便是同一个服务器的两个端口上,也会出现同样的问题)等架构来进行部署。在用户所发送的请求中,每个请求将会通过负载均衡发送到不同的服务器中。如果我们还想对集群中的......
  • 【RT-Thread基础教程】线程的基本使用
    前言在嵌入式系统开发中,RTOS(Real-TimeOperatingSystem)扮演着至关重要的角色,而RT-Thread作为一款开源的实时操作系统,在嵌入式领域中备受欢迎。线程是RTOS中的基本执行单元,其良好的多任务处理能力使得嵌入式系统能够更有效地响应各种事件和任务。本文将着重介绍在RT-Thread......
  • 为啥 两个线程同时执行 ++i,可能会导致其中一个线程的自增操作被覆盖
    这是一个典型的并发编程问题,涉及到线程的同步和共享资源的访问问题。让我们详细来看一下为什么会这样:自增操作的细节++i 看起来是一个简单的操作,但实际上它包含了多个步骤:读取变量 i 的当前值。将读取到的值加1。将结果写回变量 i。在单线程环境中,这些步骤会顺序执......
  • 《框架封装 · 线程装饰器》
    ......
  • SpringBoot使用线程池实现异步批量处理任务
    模拟批处理大量数据@Slf4j@ComponentpublicclassTestFutureService{@AutowiredprivateTestFutureServiceImpltestFutureServiceImpl;/***多线程的优势:多核CPU使用多线程可以提高CPU的利用率(单核CPU不行,反而降低),可以实现异步调用。**......
  • 多线程网络实战之仿qq群聊的服务器和客户端
    目录一、前言二、设计需求1.服务器需求 2.客户端需求三、服务端设计1.项目准备 2.初始化网络库3.SOCKET创建服务器套接字4. bind绑定套接字 5.listen监听套接字 6.accept接受客户端连接7.建立套接字数组8.建立多线程与客户端通信9.处理线程函数,收消息......
  • ThreadPoolExecutor - 管理线程池的核心类
    下面是使用给定的初始参数创建一个新的ThreadPoolExecutor(构造方法)。publicThreadPoolExecutor(intcorePoolSize,intmaximumPoolSize,longkeepAliveTime,TimeUnitun......
  • Linux系统之 — 线程
    Linux系统之—线程线程介绍线程使用死锁(Deadlock)竞态条件(RaceCondition)线程使用示例服务器端代码示例服务器端示例拆解1.引入头文件和宏定义2.定义全局变量3.定义线程函数4.主函数5.错误处理和资源释放客户端代码示例客户端示例拆解1.引入必要的头文件2.定......
  • C++的线程管理
    C++的线程管理线程类(Thread)线程构造器约定构造器初始化构造器复制构造器移动构造器多线程atomiccondition_variable应用实列futurepromise应用实列future应用实列线程类(Thread)执行线程是一个指令序列,它可以在多线程环境中,与其他此类指令序列同时执行,同时共享......
  • 线程进程2--线程安全-死锁
    5.Thread类中常用的一些方法staticvoidsleep:使当前线程阻塞多少毫秒--线程休眠yield:当前线程让出cpu参与下次竞争--使用yield线程出现交换执行的频率变高了join加入当前线程上(插入的线程执行完毕后,当前的线程才会执行)setDaemon()设置线程为守护线程(当所有的线程执行完......