我可以使用stackful协程作为steady_timer的等待处理程序吗?steady_imer是在非常stackfu
Can I use a stackful coroutine as the wait handler of a steady_timer which is defined inside the very stackful coroutine?
我可以按以下方式使用stackful协程和boost::asio::steady_timer::async_wait
吗?关键是(我的理解是,不确定)在等待期间,局部变量timer
不在堆栈上,因此无法访问。那么回调能正常进行吗?(仅供参考,它在我的Mac上使用clang++5.0运行良好。)
boost::asio::io_service io;
void Work(boost::asio::yield_context yield) {
boost::asio::steady_timer timer(io);
timer.expires_from_now(std::chrono::seconds(5));
timer.async_wait(yield);
cout << "Woke up." << endl;
}
int main() {
boost::asio::spawn(io, Work);
io.run();
return 0;
}
我认为值得对这个问题进行比较:提高asio deadline_timer
是的,将boost::asio::yield_context
传递给在同一协程中具有自动存储持续时间的对象是安全的。
Boost.Coroutine使用Boost.Context来执行上下文切换。Boost.Context提供了一种方法来挂起当前执行路径,保留堆栈(包括局部变量,如Work()
的timer
),并传输执行控制,允许同一线程使用不同的堆栈运行。因此,对于具有自动存储持续时间的boost::asio::steady_timer
对象,其寿命将在以下情况之一时结束:
- 控件通过
return
退出由Work()
指定的块,到达函数末尾,或者异常展开堆栈 - 关联的
io_service
被销毁。内部处理程序维护协程的共享所有权,当io_service
被销毁时,所有关联的处理程序也被销毁。这种破坏将导致Boost.Coroutine强制每个协同程序的堆栈展开
当调用boost::asio::spawn()
时,Boost.Asio执行一些设置工作,然后将dispatch()一个内部处理程序,该处理程序将使用用户提供的函数作为入口点创建协同程序。当yield_context
对象作为处理程序传递给异步操作时,Boost.Asio将在使用完成处理程序启动异步操作后立即产生,该完成处理程序将复制结果并恢复协程。协程拥有的strand
用于保证收益发生在恢复之前。以下是示例代码的执行示例:
boost::asio::io_service io_service;
boost::asio::spawn(io_service, &Work);
`-- dispatch a coroutine creator
into the io_service.
io_service.run();
|-- invoke the coroutine creator
| handler.
| |-- create and jump into
| | into coroutine ----> Work()
: : |-- timer created
: : |-- setting timer expiration
: : |-- timer.async_wait(yield)
: : | |-- create error_code on stack
: : | |-- initiate async_wait operation,
: : | | passing in completion handler that
: : | | will resume the coroutine
| `-- return <---- | |-- yield
|-- io_service has work (the : :
| async_wait operation) : :
| ...async wait completes... : :
|-- invoke completion handler : :
| |-- copies error_code : :
| | provided by service : :
| | into the one on the : :
| | coroutine stack : :
| |-- resume ----> | `-- return error code
: : |-- cout << "Waked up." << endl;
: : |-- exiting Work() block, timer is
: : | destroyed.
| `-- return <---- `-- coroutine done, yielding
`-- no outstanding work in
io_service, return.
是的,它应该可以工作。boost::asio::steady_timer(io)在io服务上注册计时器。
相关文章:
- Mongodb c++驱动程序:如何查询元素的数组
- C++,系统无法执行指定的程序
- 在C++程序中输入的文本文件将不起作用,除非文本被复制和粘贴
- 在VS代码中交叉编译Windows与Linux上的MinGW的SDL程序
- C++ Windows 驱动程序MSB3030无法复制该文件,因为它找不到
- 重载操作程序时出错>>用于类中的字符串 memebr
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 试图在visual studio上用C++创建一个桌面应用程序
- 模板元程序查找相似的连续类型名称
- FFmpeg:制作一个应用程序比直接使用ffmepg更好吗
- 如何通过cpp程序运行shell脚本
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- IPC使用多个管道和分支进程来运行Python程序
- 如何将c++程序的一些输出传递给shell,以便在shell中使用
- 使用C++程序合并排序没有得到正确的输出
- 基于boost的程序的静态链接——zlib问题
- 程序崩溃并显示"std::out_of_range"错误
- 在C应用程序中运行C++(带有STL)函数
- 使用mongocxx驱动程序时包含头文件问题
- 如何在c++程序中找到函数的地址