git-svn-id: svn://db.shs.com.ru/pip@884 12ceb7fc-bf1f-11e4-8940-5bc7170c53b5
56 lines
1.4 KiB
C++
56 lines
1.4 KiB
C++
#include "executor.h"
|
|
|
|
|
|
PIThreadPoolExecutor::PIThreadPoolExecutor(size_t corePoolSize, PIBlockingDequeue<std::function<void()>> *taskQueue_) : isShutdown_(false), taskQueue(taskQueue_) {
|
|
for (size_t i = 0; i < corePoolSize; ++i) {
|
|
PIThread * thread = new PIThread([&, i](){
|
|
auto runnable = taskQueue->poll(100, std::function<void()>());
|
|
if (runnable) {
|
|
runnable();
|
|
}
|
|
if (isShutdown_ && taskQueue->size() == 0) threadPool[i]->stop();
|
|
});
|
|
threadPool.push_back(thread);
|
|
thread->start();
|
|
}
|
|
}
|
|
|
|
|
|
bool PIThreadPoolExecutor::awaitTermination(int timeoutMs) {
|
|
PITimeMeasurer measurer;
|
|
for (size_t i = 0; i < threadPool.size(); ++i) {
|
|
int dif = timeoutMs - (int)measurer.elapsed_m();
|
|
if (dif < 0) return false;
|
|
if (!threadPool[i]->waitForFinish(dif)) return false;
|
|
}
|
|
return true;
|
|
}
|
|
|
|
|
|
void PIThreadPoolExecutor::shutdownNow() {
|
|
isShutdown_ = true;
|
|
for (size_t i = 0; i < threadPool.size(); ++i) threadPool[i]->stop();
|
|
}
|
|
|
|
|
|
PIThreadPoolExecutor::~PIThreadPoolExecutor() {
|
|
shutdownNow();
|
|
while (threadPool.size() > 0) delete threadPool.take_back();
|
|
delete taskQueue;
|
|
}
|
|
|
|
|
|
void PIThreadPoolExecutor::execute(const std::function<void()> &runnable) {
|
|
if (!isShutdown_) taskQueue->offer(runnable);
|
|
}
|
|
|
|
|
|
volatile bool PIThreadPoolExecutor::isShutdown() const {
|
|
return isShutdown_;
|
|
}
|
|
|
|
|
|
void PIThreadPoolExecutor::shutdown() {
|
|
isShutdown_ = true;
|
|
}
|