C++20协程通过co_await、co_yield、co_return实现暂停与恢复,用于异步编程和生成器;需定义含promise_type的返回类型,控制初始、最终挂起及返回行为;示例展示整数生成器和异步等待的实现机制。

C++20 引入了协程(Coroutines),它是一种可以暂停和恢复执行的函数,适用于异步编程、生成器、任务调度等场景。协程不是线程,它运行在当前线程中,通过 co_await、co_yield 或 co_return 来标记一个函数为协程。
只要函数体内包含以下任意一个关键字,编译器就会将其视为协程:
例如:
#include <coroutine>
#include <iostream>
<p>struct [[nodiscard]] task {
struct promise_type {
task get_return_object() { return {}; }
std::suspend_never initial_suspend() { return {}; }
std::suspend_never final_suspend() noexcept { return {}; }
void return_void() {}
void unhandled_exception() {}
};
};</p><p>task my_coroutine() {
std::cout << "协程开始\n";
co_await std::suspend_always{};
std::cout << "协程恢复\n";
co_return;
}</p>要使用协程,必须定义一个返回类型,该类型包含嵌套的 promise_type。这个结构决定了协程的行为。
立即学习“C++免费学习笔记(深入)”;
常见成员函数包括:
std::suspend_always 暂停,std::suspend_never 不暂停)常见用途之一是实现惰性生成器。下面是一个简单的整数生成器示例:
#include <coroutine>
#include <iostream>
#include <exception>
<p>template<typename T>
struct generator {
struct promise<em>type {
T value</em>;
generator get_return_object() { return generator{this}; }
std::suspend_always initial_suspend() { return {}; }
std::suspend_always final_suspend() noexcept { return {}; }
std::suspend_always yield<em>value(T value) {
value</em> = value;
return {};
}
void return_void() {}
void unhandled_exception() { std::terminate(); }
};</p><pre class='brush:php;toolbar:false;'>using handle_type = std::coroutine_handle<promise_type>;
explicit generator(promise_type* p)
: coro_(handle_type::from_promise(*p)) {}
~generator() { if (coro_) coro_.destroy(); }
bool move_next() {
if (!coro_ || coro_.done()) return false;
coro_.resume();
return !coro_.done();
}
T current_value() const { return coro_.promise().value_; }private: handletype coro; };
generator<int> range(int from, int to) { for (int i = from; i < to; ++i) { co_yield i; } }
int main() { for (auto g = range(1, 6); g.move_next();) { std::cout << g.current_value() << ' '; } std::cout << '\n'; return 0; }
输出:
1 2 3 4 5你可以定义自己的可等待类型,实现异步操作的挂起与恢复。
struct suspend_immediate {
bool await_ready() { return false; } // 立即挂起
void await_suspend(std::coroutine_handle<> h) {
std::cout << "协程被挂起,即将恢复...\n";
h.resume(); // 立即恢复(可用于调度)
}
void await_resume() {}
};
<p>generator<void> async_example() {
std::cout << "第一步\n";
co_await suspend_immediate{};
std::cout << "第三步\n";
}</p>这段代码会依次输出:
第一步说明协程在 co_await 处暂停,并由 await_suspend 控制何时恢复。
基本上就这些。C++20 协程底层灵活但需要手动封装,建议结合现有库如 cppcoro 或 Boost.Asio 来简化使用。不复杂但容易忽略细节。
以上就是c++++20中的协程(coroutines)怎么用_c++20协程使用方法的详细内容,更多请关注php中文网其它相关文章!
c++怎么学习?c++怎么入门?c++在哪学?c++怎么学才快?不用担心,这里为大家提供了c++速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号