异步操作。
现在,我通过预分配的字节的缓冲区,例如:
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));
}
}