当使用boost::asio::use_awaitable和C++ 20协同器时,我试图找到一种方法来钩住自定义分配器。给定此功能草图:
asio::awaitable<void> process_request(asio::ip::tcp::socket sock)
{
// Prepare the beast http buffer and request stuff using the custom allocator
...
fmt::print(stdout, "Reading\n");
co_await http::async_read(sock, buffer, req, asio::use_awaitable);
fmt::print(stdout, "Done reading\n");
// Prepare the beast http buffer and response stuff using the custom allocator
...
fmt::print(stdout, "Writing\n");
co_await http::async_write(sock, res, asio::use_awaitable);
fmt::print(stdout, "Done!\n\n");
}
并且覆盖全局运算符new/delete,我对分配进行了一些跟踪,并将其中的大部分链接到自定义分配器。以下是我的问题:
use_awaitable
时为读/写处理程序挂接自定义分配器?我看到在读取打印之间有288字节的分配,在写入打印之间有408字节的分配。我认为这是asio内部为处理程序所做的分配。我读过这里关于如何为回调插件提供自定义分配器的文章,但我想不出如何为这种完成令牌提供自定义分配器。Asio似乎提供了一种将分配程序与use_future
连接在一起的方法,而不是use_awaitable
。谢谢。
发布于 2022-04-13 12:12:01
我问自己同样的问题(只是出于好奇,所以我没有亲自测试下面的问题),并且在一些评论(从ASIO的创建者到原始ASIO存储库中的github问题 )中找到了一个答案。注释的示例代码如下所示。
awaitable<void> foo()
{
my_pre_allocatated_storage_type my_storage;
my_custom_allocator my_alloc(my_storage);
...
co_await my_operation(/*...*/, bind_allocator(my_alloc, use_awaitable));
}
但是,使用的bind_allocator调用是在2022年2月24日添加的,目前没有出现在Boost.Asio中(Boost 1.78.0)。如果您想通过Boost使用此功能,您可能只需等待一段时间。
https://stackoverflow.com/questions/71000159
复制相似问题