A completion token that represents the currently executing resumable coroutine.
template< typename Executor = any_io_executor> struct use_coro_t
Name |
Description |
---|---|
Adapts an executor to add the use_coro_t completion token as the default. |
Name |
Description |
---|---|
as_default_on [static] |
Function helper to adapt an I/O object to use use_coro_t as its default completion token type. |
use_coro_t [constructor] |
Default constructor. |
The use_coro_t
class, with its value use_coro
,
is used to represent an operation that can be awaited by the current resumable
coroutine. This completion token may be passed as a handler to an asynchronous
operation. For example:
coro<void> my_coroutine(tcp::socket my_socket) { std::size_t n = co_await my_socket.async_read_some(buffer, use_coro); ... }
When used with co_await, the initiating function (async_read_some
in the above example) suspends the current coroutine. The coroutine is resumed
when the asynchronous operation completes, and the result of the operation
is returned.
Header: asio/experimental/use_coro.hpp
Convenience header: None