我正在使用协程来玩asio,并想测试如何调用异步函数。我有以下代码:想知道为什么我不能只捕获协程的asio :: handler_type的引用
void async_foo(boost::asio::io_service& io_service, boost::asio::yield_context& yield)
{
using handler_type = boost::asio::handler_type<decltype(yield), void()>::type;
handler_type handler(std::forward<handler_type>(yield));
boost::asio::async_result<decltype(handler)> result(handler);
auto timer(std::make_shared<boost::asio::deadline_timer>(io_service, boost::posix_time::seconds(1)));
// the program crashes if I use &handler here
timer->async_wait([&handler](const boost::system::error_code) {
std::cout << "enter" << std::endl;
handler();
std::cout << "done" << std::endl;
});
result.get();
std::cout << "function finished" << std::endl;
return;
}
int main()
{
boost::asio::io_service io_service;
boost::asio::spawn(io_service, [&io_service](boost::asio::yield_context yield) {
std::cout << "hello" << std::endl;
async_foo(io_service, yield);
std::cout << "world" << std::endl;
});
io_service.run();
return 0;
}
这很奇怪,如果我把&处理程序捕获列表中的执行流将被搞砸了,然后它击中分段错误。但是,如果我使用“处理程序”而不是任何问题运行(然后我需要在lambda当然副本)。
搜索过,找不到任何相关的内容。预先感谢您的帮助。
谢谢你很多关于详细的说明。我在ctor和dtor中放置了一个输出的测试对象,显然在定时器触发之前有一个堆栈展开。 –