2019-11-08 02:56:32 +08:00
|
|
|
#include "pch.h"
|
|
|
|
|
|
|
|
#include "on_thread_executor.h"
|
|
|
|
|
2020-03-05 18:07:06 +08:00
|
|
|
OnThreadExecutor::OnThreadExecutor() :
|
|
|
|
_shutdown_request{ false }, _worker_thread{ [this] { worker_thread(); } }
|
|
|
|
{
|
|
|
|
}
|
2019-11-08 02:56:32 +08:00
|
|
|
|
2020-03-05 18:07:06 +08:00
|
|
|
std::future<void> OnThreadExecutor::submit(task_t task)
|
|
|
|
{
|
|
|
|
auto future = task.get_future();
|
|
|
|
std::lock_guard lock{ _task_mutex };
|
|
|
|
_task_queue.emplace(std::move(task));
|
|
|
|
_task_cv.notify_one();
|
|
|
|
return future;
|
2019-11-08 02:56:32 +08:00
|
|
|
}
|
|
|
|
|
2020-03-05 18:07:06 +08:00
|
|
|
void OnThreadExecutor::worker_thread()
|
|
|
|
{
|
|
|
|
while (!_shutdown_request)
|
2019-11-08 02:56:32 +08:00
|
|
|
{
|
2020-03-05 18:07:06 +08:00
|
|
|
task_t task;
|
|
|
|
{
|
|
|
|
std::unique_lock task_lock{ _task_mutex };
|
|
|
|
_task_cv.wait(task_lock, [this] { return !_task_queue.empty() || _shutdown_request; });
|
|
|
|
if (_shutdown_request)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
task = std::move(_task_queue.front());
|
|
|
|
_task_queue.pop();
|
|
|
|
}
|
|
|
|
task();
|
2019-11-08 02:56:32 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-03-05 18:07:06 +08:00
|
|
|
OnThreadExecutor::~OnThreadExecutor()
|
|
|
|
{
|
|
|
|
_shutdown_request = true;
|
|
|
|
_task_cv.notify_one();
|
|
|
|
_worker_thread.join();
|
2019-11-08 02:56:32 +08:00
|
|
|
}
|