提升asio缓冲区的懒惰分配

时间:2013-01-07 22:07:54

标签: c++ boost boost-asio

异步操作。

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

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

是否可以为此呼叫和其他呼叫进行延迟分配?

1 个答案:

答案 0 :(得分:8)

延迟分配或allocating when the resource is needed可以使用boost::asio::null_buffers完成。 null_buffers可用于在Boost.Asio中获取reactor样式的操作。这对于与第三方库集成,使用共享内存池等非常有用.Boost.Asio documentation提供了一些信息和以下示例代码:

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));
  }
}