完整代码
TaskPool.cpp
#include "TaskPool.h"
#include <functional>
std::mutex printMutex;
TaskPool::TaskPool() : m_bRunning(false)
{
}
TaskPool::~TaskPool()
{
removeAllTasks();
}
void TaskPool::init(int threadNum)
{
if (threadNum <= 0)
threadNum = 5;
m_bRunning = true;
for (int i = 0; i < threadNum; i++) {
std::shared_ptr<std::thread> spThread;
spThread.reset(new std::thread(std::bind(&TaskPool::threadFunc, this)));
{
std::lock_guard<std::mutex> guard(printMutex);
std::cout << "Init a thread, id: "<< spThread->get_id() << std::endl;
}
m_threads.push_back(spThread);
}
}
void TaskPool::stop()
{
m_bRunning = false;
m_cv.notify_all();
for (auto& it : m_threads) {
if (it->joinable())
it->join();
}
}
void TaskPool::addTask(Task *task)
{
std::shared_ptr<Task> spTask;
spTask.reset(task);
{
std::lock_guard<std::mutex> guard(m_mutexList);
m_taskList.push_back(spTask);
}
{
std::lock_guard<std::mutex> guard(printMutex);
std::cout << "add a Task, id: " << spTask->getID() << ", thread id is: " << std::this_thread::get_id() << std::endl;
}
m_cv.notify_one();
}
void TaskPool::removeAllTasks()
{
{
std::lock_guard<std::mutex> guard(m_mutexList);
for (auto& it : m_taskList) {
it.reset();
}
m_taskList.clear();
}
}
void TaskPool::threadFunc()
{
std::shared_ptr<Task> spTask;
while (true) {
{
std::unique_lock<std::mutex> guard(m_mutexList);
while (m_taskList.empty()) {
if (!m_bRunning)
break;
m_cv.wait(guard);
}
if (!m_bRunning)
break;
spTask = m_taskList.front();
m_taskList.pop_front();
}
if (spTask == NULL)
continue;
spTask->doIt();
spTask.reset();
}
std::lock_guard<std::mutex> guard(printMutex);
std::cout << "exit thread , threadID:" << std::this_thread::get_id() << std::endl;
}
TaskPool.h
#ifndef UNTITLED_TASKPOOL_H
#define UNTITLED_TASKPOOL_H
#include<thread>
#include<mutex>
#include<condition_variable>
#include<list>
#include<vector>
#include<memory>
#include<iostream>
extern std::mutex printMutex;
class Task{
private:
unsigned int id;
public:
Task(unsigned int ID)
{
id = ID;
}
virtual void doIt()
{
std::lock_guard<std::mutex> guard(printMutex);
std::cout << "handle a task ,TaskID is: "<< id << ", thradID is:" << std::this_thread::get_id() << std::endl;
}
virtual ~Task()
{
std::lock_guard<std::mutex> guard(printMutex);
std::cout << "a task destructed , TaskID is: "<< id << ", thradID is:" << std::this_thread::get_id() << std::endl;
}
unsigned int getID()
{
return id;
}
};
class TaskPool final{
public:
TaskPool();
~TaskPool();
TaskPool(const TaskPool& rhs) = delete;
TaskPool& operator=(const TaskPool& rhs) = delete;
public:
void init(int threadNum = 5);
void stop();
void addTask(Task* task);
void removeAllTasks();
private:
void threadFunc();
private:
std::list<std::shared_ptr<Task>> m_taskList;
std::mutex m_mutexList;
std::condition_variable m_cv;
bool m_bRunning;
std::vector<std::shared_ptr<std::thread>> m_threads;
};
#endif
main.cpp
#include<chrono>
#include "TaskPool.h"
int main()
{
TaskPool threadPool;
threadPool.init();
Task* task = NULL;
for (int i = 0; i < 10; i++) {
task = new Task(i);
threadPool.addTask(task);
}
std::this_thread::sleep_for(std::chrono::seconds(5));
threadPool.stop();
return 0;
}