温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

TP框架中的消息队列实现

发布时间:2024-08-27 02:07:52 来源:亿速云 阅读:81 作者:小樊 栏目:编程语言

TP(Thread Pool,线程池)框架是一种用于管理和调度线程资源的技术,它可以提高系统性能,减少线程创建和销毁的开销。在TP框架中,消息队列是一种常用的任务调度和处理机制。以下是一个简单的消息队列实现:

  1. 首先,定义一个任务类(Task),它包含了要执行的任务信息和任务处理函数。
class Task {
public:
    virtual void execute() = 0; // 纯虚函数,子类需要实现具体的任务处理逻辑
};
  1. 创建一个消息队列类(MessageQueue),它使用一个线程安全的队列(如std::queue)来存储任务对象。
#include<queue>
#include <mutex>
#include<condition_variable>

class MessageQueue {
public:
    void push(Task* task) {
        std::unique_lock<std::mutex> lock(mutex_);
        queue_.push(task);
        cv_.notify_one(); // 通知等待的线程有新任务到来
    }

    Task* pop() {
        std::unique_lock<std::mutex> lock(mutex_);
        cv_.wait(lock, [this] { return !queue_.empty(); }); // 当队列为空时,线程等待
        Task* task = queue_.front();
        queue_.pop();
        return task;
    }

private:
    std::queue<Task*> queue_;
    std::mutex mutex_;
    std::condition_variable cv_;
};
  1. 创建一个线程池类(ThreadPool),它包含了多个工作线程,这些线程会从消息队列中获取任务并执行。
#include<vector>
#include<thread>

class ThreadPool {
public:
    ThreadPool(size_t num_threads, MessageQueue& message_queue) : message_queue_(message_queue) {
        for (size_t i = 0; i < num_threads; ++i) {
            threads_.emplace_back(&ThreadPool::worker, this);
        }
    }

    ~ThreadPool() {
        for (auto& thread : threads_) {
            if (thread.joinable()) {
                thread.join();
            }
        }
    }

    void add_task(Task* task) {
        message_queue_.push(task);
    }

private:
    void worker() {
        while (true) {
            Task* task = message_queue_.pop();
            if (task) {
                task->execute();
                delete task; // 任务执行完毕后,释放任务对象内存
            }
        }
    }

    std::vector<std::thread> threads_;
    MessageQueue& message_queue_;
};
  1. 使用示例:
class MyTask : public Task {
public:
    MyTask(int data) : data_(data) {}

    void execute() override {
        // 在这里实现具体的任务处理逻辑
        std::cout << "Processing task with data: "<< data_<< std::endl;
    }

private:
    int data_;
};

int main() {
    MessageQueue message_queue;
    ThreadPool thread_pool(4, message_queue); // 创建一个包含4个工作线程的线程池

    // 添加任务到线程池
    for (int i = 0; i < 10; ++i) {
        thread_pool.add_task(new MyTask(i));
    }

    // 主线程等待用户输入,以便观察任务执行情况
    std::cin.get();

    return 0;
}

这个简单的TP框架中的消息队列实现可以根据实际需求进行扩展和优化。例如,可以添加任务优先级、限制队列大小等功能。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI