如何解决如何使类方法成为协程?
如何使类方法成为协程?这是一个小例子。这里我试图从一个类方法创建一个协程,但是编译器抛出以下错误:
错误:无法找到此协程的承诺类型
52 | std::vector vec = co_await awaitable_func1();
如何为方法正确设置 coroutine_traits?
auto awaitable_func1() {
struct Awaitable {
std::vector<int> vec;
bool await_ready() { return false; }
void await_suspend(std::coroutine_handle<> coroutine) {
vec = std::vector<int>{1,2,3,4,5};
coroutine.resume();
}
auto await_resume() {
return vec;
}
};
return Awaitable{};
}
class Coroutine {
public:
void call(int);
};
struct Promise {
Promise(Coroutine){}
void get_return_object() {}
std::suspend_never initial_suspend() { return {}; }
std::suspend_never final_suspend() { return {}; }
void return_void() {}
void unhandled_exception() { std::terminate(); }
};
template<>
struct std::coroutine_traits<void,Coroutine,int> {
using promise_type = Promise;
};
void Coroutine::call(int a) {
std::vector<int> vec = co_await awaitable_func1();
for (size_t i = 0; i < vec.size(); i++) {
std::cout << vec[i] + a << std::endl;
}
}
int main() {
Coroutine a;
a.call(5);
return 0;
};
解决方法
抛开返回 void
的道德规范,需要进行以下更改才能使 GCC 编译它:
-
您将错误的
Coroutine
类型作为*this
参数传递。它需要是一个参考:struct std::coroutine_traits<void,Coroutine&,int> {
-
final_suspend
必须是noexcept
:std::suspend_never final_suspend() noexcept { return {}; }
-
promise 构造函数必须可以使用 0 个参数或协程的所有参数调用:
Promise(Coroutine& this_,int& a){} // Option 1,take by value if you want to copy,use const as desired Promise(){} // Option 2,applicable if you don't need the parameters
据我从标准文本来看,这三个是正确的错误。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。