-
Notifications
You must be signed in to change notification settings - Fork 72
/
async_op_1.cpp
81 lines (64 loc) · 1.81 KB
/
async_op_1.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#include <experimental/executor>
#include <experimental/loop_scheduler>
#include <experimental/thread_pool>
#include <iostream>
#include <string>
using std::experimental::bind_executor;
using std::experimental::dispatch;
using std::experimental::loop_scheduler;
using std::experimental::make_work_guard;
using std::experimental::post;
using std::experimental::thread_pool;
// A function to asynchronously read a single line from an input stream.
template <class Handler>
void async_getline(std::istream& is, Handler handler)
{
// Create executor_work for the handler's associated executor.
auto work = make_work_guard(handler);
// Post a function object to do the work asynchronously.
post([&is, work, handler=std::move(handler)]() mutable
{
std::string line;
std::getline(is, line);
// Pass the result to the handler, via the associated executor.
dispatch(work.get_executor(),
[line=std::move(line), handler=std::move(handler)]() mutable
{
handler(std::move(line));
});
});
}
class line_printer
{
public:
typedef loop_scheduler::executor_type executor_type;
explicit line_printer(loop_scheduler& s)
: executor_(s.get_executor())
{
}
executor_type get_executor() const noexcept
{
return executor_;
}
void operator()(std::string line)
{
std::cout << "Line: " << line << "\n";
}
private:
loop_scheduler::executor_type executor_;
};
int main()
{
thread_pool pool;
std::cout << "Enter a line: ";
async_getline(std::cin,
bind_executor(pool, [](std::string line)
{
std::cout << "Line: " << line << "\n";
}));
pool.join();
loop_scheduler scheduler;
std::cout << "Enter another line: ";
async_getline(std::cin, line_printer(scheduler));
scheduler.run();
}