代码拉取完成,页面将自动刷新
#pragma once
#include <thread>
#include <mutex>
#include <vector>
#include <queue>
#include <atomic>
#include <functional>
#include <condition_variable>
#include <map>
#include <future>
using namespace std;
// ̳߳
class ThreadPool
{
public:
ThreadPool(int min = 4, int max = thread::hardware_concurrency());
~ThreadPool();
void addTask(function<void()> f);
template<typename F, typename... Args>
auto addTask(F&& f, Args&&... args) -> future<typename result_of<F(Args...)>::type>
{
using returnType = typename result_of<F(Args...)>::type;
auto task = make_shared<packaged_task<returnType()>>(
bind(forward<F>(f), forward<Args>(args)...)
);
future<returnType> res = task->get_future();
{
unique_lock<mutex> lock(m_queueMutex);
m_tasks.emplace([task]() { (*task)(); });
}
m_condition.notify_one();
return res;
}
private:
void manager();
void worker();
private:
thread* m_manager;
map<thread::id, thread> m_workers;
vector<thread::id> m_ids;
int m_minThreads;
int m_maxThreads;
atomic<bool> m_stop;
atomic<int> m_curThreads;
atomic<int> m_idleThreads;
atomic<int> m_exitNumber;
queue<function<void()>> m_tasks;
mutex m_idsMutex;
mutex m_queueMutex;
condition_variable m_condition;
};
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。