如何解决有什么优雅的方法可以将 c++20 协程句柄传到外部?
我们知道c++20协程在使用co_await awaitable后会挂起并返回调用者,如果我们想恢复这个协程,唯一的办法就是从awaitable对象函数 void await_suspend(std::coroutine_handle<> cont) const
中获取协程句柄,然后使用handle .resume() 来恢复协程,有什么办法可以从协程外部获取协程句柄或者有什么更好的方法来恢复协程?
解决方法
从广义上讲,您不应该希望从协程机器外部获取句柄。如果您这样做了,很可能您没有按照预期使用的方式使用协程。
在 C++20 中设计的协程的想法是不可见。也就是说,从协程之外的代码的角度来看,没有人应该知道它是作为协程实现的。它只是一个返回某种类型的函数,该类型表示将来可以获得的值;它如何实现这一点是一个实现细节。
“恢复协程”的意思是告诉协程函数返回的未来对象产生值。这应该只是对未来对象的常规 API 调用。是future对象可以访问promise,promise可以访问协程句柄来恢复它。
此外,除非协程是生成器,否则直接恢复协程执行的代码旨在成为协程 co_await
上的“awaitable”。也就是说,有一些进程会产生一个值,你 co_await
在这个进程返回的未来,一旦值准备好,这个进程将恢复你的协程。如果其他人需要 co_await
您的协程产生的值,那很好。您的承诺/未来机器将在您的协程完成时恢复它们,并赋予它们您的承诺的价值。
这就是 co_await
协程要恢复的方式。此过程之外的代码不需要句柄,也不应该获得句柄。
在任何情况下,除非协程的承诺/未来机制明确为您提供提取句柄的 API,否则您无法获得句柄。
,好吧,我找到了一个更好的方法,通过引用c++23 std::generator从调用者恢复协程,如下所示:
struct Result{
//add
Result(promise_type* obj):promise_type_ptr(obj){}
//add
void resume(){
promise_type_ptr->resume();
}
struct promise_type {
// mod
Result get_return_object() {
return Reuslt(this);
}
// add
void resume(){
coroutine_handle<promise_type>::from_promise(*this).resume();
}
std::suspend_never initial_suspend() { return {}; }
std::suspend_never final_suspend() noexcept { return {}; }
void unhandled_exception() {}
suspend_aways yield_value(){}
void return_void() {}
Result return_value(const Result& res){ return res;}
};
// add
promise_type *promise_type_ptr;
};
我们可以使用coroutine_handle<promise_type>::from_promise(*this);
从promise_type对象指针中获取协程句柄,所以我们可以在协程返回结果中创建一个函数resume()
给调用者,如下使用
auto result = CoroutineFunction();
result.resume();
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。