#include<iostream>
#include<functional>
#include<thread>
#include<condition_variable>
#include<mutex>
#include<queue>
#define ThreadNum 555
#define POOL P
using namespace std;
void func(int);
class P
{
public:
P()
{
isRunning = true;
for (int i = 0; i<ThreadNum; i++)
{
threads.emplace([this,i]()
{
std::cout << i << std::endl;
while (isRunning)
{
std::unique_lock<std::mutex>lk(mtx);
cv.wait(lk, [this](){return isRunning && !tasks.empty(); });
Task nowTask =std::move(tasks.front());
tasks.pop();
nowTask();
}
; });
}
}
~P()
{
while (!threads.empty())
{
std::thread t = std::move(threads.front());
if (t.joinable())
{
t.join();
};
}
}
void commit(int id)
{
Task newtask = std::bind(func,id);
std::lock_guard < std::mutex>lk(mtx);
tasks.emplace(newtask);
cv.notify_one();
}
void stop()
{
std::unique_lock<std::mutex>lk(mtx);
isRunning = false;
}
private:
std::mutex mtx;
std::condition_variable cv;
using Task = std::function<void(void)>;
using WorkThread = std::thread;
std::queue<Task>tasks;
bool isRunning;
std::queue<WorkThread>threads;
};
void func(int id)
{
printf("%d\n", id);
}
int main()
{
POOL p;
for (int i = 0; i < 10; i++)
{
p.commit(i);
}
//cin.get();
}
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
C++11实现的线程池:ThreadPool
github地址:https://github.com/progschj/ThreadPool关于其使用,详见:C++11并发学习之六:线程池的实现
C++11 线程池 线程 ThreadPool github -
C++11 ——— 线程库
在C++11之前,涉及到多线程问题,都是和平台相关的,比如Windows和Linux下各有自
c++ 开发语言 加锁 互斥锁 互斥量 -
C++11实现简易定时器
定时器timer是多线程编程中经常设计到的工具类定时器的原理其实很简单:创建一个新线程在那个线程里等待等待
c++ 开发语言 后端 #include ios