std::generator是C++23引入的协程组件,用于惰性生成值序列。它定义于头文件,通过co_yield暂停并返回值,支持range-based for循环,实现类似Python生成器的行为,但具有类型安全和高性能优势,适用于数据流处理等场景。
在C++23中,std::generator 是一个基于协程(coroutine)的新标准库组件,它允许你以类似Python生成器的方式惰性地产生一系列值。这意味着你可以写一个函数,在每次被迭代时“暂停”并返回一个值,之后从中断处继续执行,直到结束。
std::generator 是 头文件中定义的模板类型,用于表示一个可懒加载值的序列。它的基本形式是:
std::generator:生成 T 类型的值序列例如,你可以这样写一个生成斐波那契数列的函数:
std::generatorfibonacci() { int a = 0, b = 1; while (true) { co_yield a; std::swap(a, b); b += a; } }
然后像使用普通容器一样遍历它:
for (int n : fibonacci()) {
if (n > 100) break;
std::cout << n << " ";
}
// 输出: 0 1 1 2 3 5 8 13 21 34 55 89
C++ 的生成器依赖于三个关键字和协程框架:
当函数返回 std::generator 并包含 co_yield 时,编译器会将其编译为协程。每次调用迭代器的 operator++() 或进入 range-based for 的下一轮循环,协程就会从上次 co_yield 的地方恢复运行。
下面是一个生成偶数的例子:
std::generatoreven_numbers(int limit) { for (int i = 0; i < limit; i += 2) { co_yield i; } } // 使用方式 for (int x : even_numbers(10)) { std::co ut << x << " "; } // 输出: 0 2 4 6 8
Python 中常见的生成器写法如下:
def fibonacci():
a, b = 0, 1
while True:
yield a
a, b = b, a + b
C++23 的 std::generator 实现了几乎相同的语义:
yield 关键字(C++ 是 co_yield)区别在于:
std::generator
(C++23 新增)基本上就这些。std::generator 让 C++ 拥有了类似 Python 的简洁生成器语法,同时保留了高性能和类型安全的优势,特别适合处理大数据流、树遍历、状态机等场景。虽然还在推广初期,但已经是现代 C++ 异步编程的重要一环。