提高ASIO缓冲懒分配(boost asio buffer lazy allocation)

2019-07-17 23:19发布

异步操作。

现在,我通过预分配的字节的缓冲区,例如:

s.async_receive_from(
    boost::asio::buffer( preallocated_pointer, preallocated_size ),
    _remote_endpoint,
    boost::bind(...)
    );

是否有可能使懒惰的分配,这和其他的电话?

Answer 1:

懒惰分配或分配需要的资源时 ,可以使用来实现boost::asio::null_buffersnull_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));
  }
}


文章来源: boost asio buffer lazy allocation