<C++> 基于C++11/14/17的线程池实现

本文介绍了如何在C++11/14/17中实现线程池,强调了线程池在并发场景下的性能提升,并提供了具体的代码实现。线程池通过预先启动的线程进行任务调度,避免频繁创建和销毁线程的开销。文章详细讲解了核心的`ThreadPool`类设计,包括启动工作线程、任务调度及任务提交等功能,并给出了性能测试结果。
摘要由CSDN通过智能技术生成

线程池,顾名思义就是预先启动一些线程,集中管理,需要的时候直接拿来用,无需用时再创建。尤其是在Windows平台,线程是稀缺资源,线程的创建和销毁都是十分耗时的,所以利用线程池来提升并发场景下的性能,是十分有必要的。

C++11首次对并发进行了支持,这使得我们利用STL编写多线程应用程序成为了可能,不过STLthread比较简陋,并没有提供更多的强大特性,只是一个最基础的多线程解决方案,定位应该是尽可能面向更多应用场景的最通用的版本。

先上代码:Thread Pool
为了拥抱新标准,尽量使用了C++14/17的特性,所以如果需要编译运行这些代码的话,需要启用你的编译器的c++17特性。

本文不对thread,mutex,condition_variable作过多解释,不知道的同学可以去查阅相关资料 ——> cpp_reference

首先我们定义设计ThreadPool这个类的接口:

class ThreadPool {
    public:
        explicit ThreadPool(const size_t& max_threads);

        template<class Func, typename... Args>
        decltype(auto) submitTask(Func&& func, Args&&... args);
        void pause();
        void unpause();
        void close();
        bool isClosed() const;
        ~ThreadPool();
    protected:
        void _scheduler();
        void _launchNew();
    private:
        static size_t core_thread_count;
        size_t max_thread_count;
        // thread-manager
        std::vector<std::thread> threads;
        // tasks-queue
        std::queue<std::function<void()>> tasks;
        // for synchronization
  
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值