117.info
人生若只如初见

C++ Task和线程池的配合使用

在C++中,可以使用Task和线程池来实现并发执行任务的功能。Task代表一个可执行的任务,可以是一个函数或者一个类的成员函数。线程池则是一组线程,用来执行任务队列中的任务。

以下是一个简单的示例代码,演示如何在C++中使用Task和线程池:

#include 
#include 
#include 
#include 
#include 
#include 
#include 

class Task {
public:
    Task(std::function func) : m_func(func) {}

    void execute() {
        m_func();
    }

private:
    std::function m_func;
};

class ThreadPool {
public:
    ThreadPool(int numThreads) {
        for (int i = 0; i < numThreads; ++i) {
            m_threads.emplace_back([this] {
                while (true) {
                    Task* task = nullptr;
                    {
                        std::unique_lock lock(m_mutex);
                        m_condition.wait(lock, [this] { return !m_tasks.empty(); });
                        task = m_tasks.front();
                        m_tasks.pop();
                    }
                    task->execute();
                    delete task;
                }
            });
        }
    }

    ~ThreadPool() {
        for (std::thread& thread : m_threads) {
            thread.join();
        }
    }

    template
    void addTask(F&& func, Args&&... args) {
        auto task = new Task(std::bind(std::forward(func), std::forward(args)...));
        {
            std::lock_guard lock(m_mutex);
            m_tasks.push(task);
        }
        m_condition.notify_one();
    }

private:
    std::vector m_threads;
    std::queue m_tasks;
    std::mutex m_mutex;
    std::condition_variable m_condition;
};

void printNumber(int number) {
    std::cout << "Number: " << number << std::endl;
}

int main() {
    ThreadPool threadPool(4);

    for (int i = 0; i < 10; ++i) {
        threadPool.addTask(printNumber, i);
    }

    std::this_thread::sleep_for(std::chrono::seconds(1));

    return 0;
}

在这个示例中,我们定义了一个Task类来表示一个任务,然后定义了一个ThreadPool类来管理线程池。在主函数中,我们创建一个ThreadPool对象,并向线程池中提交了10个任务,每个任务打印一个数字。最后,我们让主线程休眠一秒钟,等待所有任务执行完毕。

这样,我们就实现了在C++中使用Task和线程池配合使用的功能。通过线程池可以有效地管理线程的生命周期,并实现多线程并发执行任务的功能。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fece7AzsIAwdfA1A.html

推荐文章

  • c# winform组件 怎样集成

    在C# WinForms应用程序中集成组件通常涉及以下几个步骤: 添加引用: 首先,确保你已经安装了所需的组件。例如,如果你想要集成一个第三方库,你需要将该库的DLL...

  • c# winform组件 怎样提高效率

    要提高C# WinForms应用程序的效率,可以从多个方面入手,包括优化绘图过程、使用异步操作、合理设置控件属性等。以下是一些具体的优化策略:
    优化绘图过程 ...

  • c# winform组件 怎样自定义

    在C#中,要自定义WinForms组件,您需要创建一个继承自现有控件的新类,并重写其构造函数、事件处理程序和其他相关方法。以下是一个简单的示例,说明如何创建一个...

  • c# winform组件 怎样选择合适

    在C# WinForms应用程序开发中,选择合适的组件对于构建高效、用户友好的界面至关重要。以下是一些选择合适组件的建议:
    控件选择 根据需求选择:选择控件时...

  • C++ Task在并发编程中的应用

    在并发编程中,C++ Task是一种用于异步执行任务的机制。它可以在多线程环境下,将任务分配给不同的线程去执行,从而提高程序的性能和效率。
    C++ Task通常用...

  • C++ dictionary的迭代器安全吗

    在C++中,标准库提供的std::map和std::unordered_map等容器都是支持迭代器的。对于这些容器,迭代器通常是安全的,即在遍历容器时进行插入、删除操作不会影响迭代...

  • C++ dictionary能否自定义排序

    C++中的std::map和std::unordered_map都是基于红黑树实现的,它们是有序的容器,其中元素会根据键值的大小进行排序。因此,你可以自定义排序规则来对键值进行排序...

  • C++ dictionary如何处理冲突

    C++中的字典(例如std::unordered_map)通常使用哈希表作为底层数据结构来存储键值对。在哈希函数的映射过程中,可能会发生冲突,即两个不同的键被映射到了相同的...