// packaged_task<>模板 // 可以将可调用对象和参数封装起来,并将它们和future绑定 // 这样,只要某一个工作完成了,和它绑定的future就变成了就绪状态 // 可以用做线程池的构建,用它实现多任务队列 // 但是任务包(packaged_task)只适合用于一个简单函数的表达式调用,结果也是只来自这个函数。 // 如果一个任务,无法用一个简单的函数表示,或者结果需要来自不同的任务,任务包就很难胜任, // 就需要第三种创建future的方式:promise
/* 下面例子,使用packaged_task<> 在gui线程上运行代码,实现任务传递 */
#include <deque>
#include <mutex>
#include <future>
#include <thread>
#include <utility>
using namespace std;
mutex mut;
deque<packaged_task<void()>> tasks;
bool gui_shutdown_message_received();
void get_and_process_gui_message();
void gui_thread()
{
while (!gui_shutdown_message_received())
{
get_and_process_gui_message();
packaged_task<void()> task;
{
lock_guard<mutex> lk(mut);
if(tasks.empty())
{
continue;
}
task = move(tasks.front());
tasks.pop_front();
}
task();
}
}
thread gui_bg_thread(gui_thread);
template<typename Func>
future<void> post_task_for_gui_thread(Func f)
{
packaged_task<void()> task(f);
future<void> res = task.get_future();
lock_guard<mutex> lk(mut);
tasks.push_back(move(task));
return res;
}
|