...one of the most highly
regarded and expertly designed C++ library projects in the
world.
— Herb Sutter and Andrei
Alexandrescu, C++
Coding Standards
Start an asynchronous read.
template< class MutableBufferSequence, class ReadHandler = net::default_completion_token_t<executor_type>> DEDUCED async_read_some( MutableBufferSequence const& buffers, ReadHandler&& handler = net::default_completion_token_t< executor_type >{});
This function is used to asynchronously read data from the stream. The function call always returns immediately.
Name |
Description |
---|---|
|
One or more buffers into which the data will be read. Although the buffers object may be copied as necessary, ownership of the underlying memory blocks is retained by the caller, which must guarantee that they remain valid until the handler is called. |
|
The completion handler to invoke when the operation completes. The implementation takes ownership of the handler by performing a decay-copy. The equivalent function signature of the handler must be: void handler( error_code const & error, // result of operation std::size_t bytes_transferred // number of bytes transferred );
If the handler has an associated immediate executor, an immediate
completion will be dispatched to it. Otherwise, the handler will
not be invoked from within this function. Invocation of the handler
will be performed by dispatching to the immediate executor. If
no immediate executor is specified, this is equivalent to using
|