std::generator是C++23引入的协程返回类型,用于懒惰按需生成值,需包含头文件并启用C++23及协程支持;它可移动不可复制,配合co_yield实现暂停-恢复,支持范围for遍历,但不支持反向、随机访问或多遍历。

std::generator 是 C++23 引入的协程工具,用于懒惰地、按需生成一系列值。它不是标准库容器,而是一个协程返回类型,配合 co_yield 使用,让函数能“暂停-恢复”并逐个产出结果。
基本用法:定义一个简单生成器
要使用 std::generator,需包含头文件 <generator></generator>(注意:截至 2024 年底,GCC 13+、Clang 16+ 和 MSVC 19.35+ 支持,且需开启 C++23 和协程支持)。
下面是一个生成前 N 个斐波那契数的示例:
#include <generator>
#include <iostream>
std::generator<long long> fibonacci(int n) {
long long a = 0, b = 1;
for (int i = 0; i < n; ++i) {
if (i == 0) co_yield a;
else if (i == 1) co_yield b;
else {
long long next = a + b;
co_yield next;
a = b;
b = next;
}
}
}
// 使用方式
int main() {
for (auto x : fibonacci(10)) {
std::cout << x << " ";
}
// 输出:0 1 1 2 3 5 8 13 21 34
}
登录后复制
关键点:
立即学习“C++免费学习笔记(深入)”;
- 函数返回类型为
std::generator<t></t>,其中T是每次co_yield的值类型; - 函数体内可使用
co_yield expr暂停执行并返回值; - 生成器对象可直接用于范围 for 循环(它实现了
begin()/end()); - 每次迭代触发一次协程恢复,直到协程结束或遇到
co_return(隐式或显式)。
参数传递与状态保持
生成器函数可以接收普通参数(如上面的 int n),这些参数在协程首次调用时被拷贝进协程帧,后续每次恢复都能访问其副本。但注意:
标签: 工具 ai c++ ios stream 编译错误 标准库
还木有评论哦,快来抢沙发吧~