自定义线程池

自定义线程池

在这里插入图片描述

注意: 需要c++17c++20 的支持

代码实现:

#ifndef THREADPOOL_H
#define THREADPOOL_H

#include <vector>
#include <queue>
#include <thread>
#include <mutex>
#include <condition_variable>
#include <functional>
#include <future>
#include <atomic>
#include <iostream>

//线程池,单例类
class ThreadPool
{
   
public:
    static ThreadPool& getInstance()
    {
   
        //std::thread::hardware_concurrency() //获取线程数  最小10个线程
        static int size = std::max((int)std::thread::hardware_concurrency(),10);
        static ThreadPool instance(size,size * 2);
        return instance;
    }

    ThreadPool(ThreadPool const&) = delete;
    void operator=(ThreadPool const&) = delete;

    //增加运行的函数 动态获取类型
    template<typename F, typename... Args>
    auto enqueue(F&& f, Args&&... args) -> std::future<typename std::invoke_result<F,Args...>::type>
    {
   
        //返回类型
        using return_type = typename std::invoke_result<F,Args...>::type;
        //打包函数
        auto task = std::make_shared<std::packaged_task<return_type()> >(
            std::bind(std::forward<F>(f), std::forward<Args>(args)...)
            );

        std::future<return_type> res = task->get_future();
        {
   
            std::lock_guard <std::mutex> lock(m_queue_mutex);

            if (m_stop)
            {
   
                //return res;
     
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值