C++20协程——最简单的协程

一个函数返回了"协程接口",那么这个函数就是一个协程。

协程接口要求必须有promise_type。(awaitable是另外的,非必须。)

协程句柄(代表协程)是编译器负责创建的,我们只管用就行了。

最小化示例如下:

cpp 复制代码
#include <coroutine>

#include <iostream>

struct CoroutineInterface {
	struct promise_type {
		CoroutineInterface get_return_object() {
			return CoroutineInterface(std::coroutine_handle<promise_type>::from_promise(*this));
		}
		auto initial_suspend() {
			return std::suspend_always();
		}

		auto final_suspend()noexcept {
			return std::suspend_always();
		}
		void return_void() noexcept {

		}
		void unhandled_exception() {
			std::terminate();
		}
	};

	CoroutineInterface(std::coroutine_handle<promise_type> co_handle) {
		co_handle_ = co_handle;
	}

	std::coroutine_handle<promise_type> co_handle_;
};

CoroutineInterface GetNumbers() {
	// co_wait initial_suspend();
	for (int i = 0; i < 8; ++i) {
		std::cerr << i << "\n";
		co_await std::suspend_always();
	}
	// co_wait final_suspend();
	co_return;
}
int main(void) {

	CoroutineInterface co_interface = GetNumbers();
	while (!co_interface.co_handle_.done()) {
		std::cerr << "resume:";
		co_interface.co_handle_.resume();
	}
	std::cerr << "successfully end\n";
	return 0;
}

函数(协程)执行时,编译器会在代码块最前面执行cowait initial_suspend(),并且在函数co_return之前(或者在异常跳出之前)执行cowait final_suspend()

initial_suspend()final_suspend()是标准库提供的两个awaitable(可等待体)。

initial_suspend()final_suspend()分别用于控制协程开始、协程即将结束时是否要挂起(挂起后会转移执行权,可以转移给调用者,或者其他协程)。

相关推荐
十五年专注C++开发7 天前
UDRefl: 一个基于C++20的高性能动态反射库
c++20·反射·udrefl
前进吧-程序员7 天前
C++20 Concepts 简明介绍:模板编程的“合约时代”
c++20
w我是东山啊24 天前
C++20——协程
c++20
wangjialelele1 个月前
C++11、C++14、C++17、C++20新特性解析(一)
linux·c语言·开发语言·c++·c++20·visual studio
telllong1 个月前
C++20 Modules:从入门到真香
java·前端·c++20
Max_uuc2 个月前
【架构心法】逃离回调地狱:从 Protothreads 到 C++20 协程 (Coroutines) 的嵌入式进化
c++20
阿猿收手吧!2 个月前
【C++】C++20协程的await_transform和coroutine_handle
开发语言·c++·c++20
阿猿收手吧!2 个月前
【C++】 co_yield如何成为语法糖?解析其背后的Awaitable展开与协程状态跃迁
c++·c++20
吐泡泡_2 个月前
C++20(三路比较运算符)
c++20
啟明起鸣2 个月前
【C++20新特性】概念约束特性与 “模板线程池”,概念约束是为了 “把握未知对象”
开发语言·c++·c++20·模板线程池