异步操作。
现在,我传递预分配的字节缓冲区,例如:
s.async_receive_from(
boost::asio::buffer( preallocated_pointer, preallocated_size ),
_remote_endpoint,
boost::bind(...)
);
是否可能对此及其他调用进行惰性分配?
异步操作。
现在,我传递预分配的字节缓冲区,例如:
s.async_receive_from(
boost::asio::buffer( preallocated_pointer, preallocated_size ),
_remote_endpoint,
boost::bind(...)
);
是否可能对此及其他调用进行惰性分配?
boost::asio::null_buffers
来完成。 null_buffers
可以用于在Boost.Asio中获得反应堆式操作。这对于与第三方库集成、使用共享内存池等非常有用。 Boost.Asio 文档提供了一些信息和以下示例代码:ip::tcp::socket socket(my_io_service);
...
socket.non_blocking(true);
...
socket.async_read_some(null_buffers(), read_handler);
...
void read_handler(boost::system::error_code ec)
{
if (!ec)
{
std::vector<char> buf(socket.available());
socket.read_some(buffer(buf));
}
}