生成器通过yield实现惰性加载,适合处理大数据集。函数使用yield返回值,支持键值对和嵌套委托,但只能遍历一次且不可计数。

PHP中的生成器(Generator)是一种能实现惰性加载的轻量级协程机制,它通过 yield 关键字来逐个返回值,而不是一次性生成所有结果。这种方式特别适合处理大数据集或无限序列,节省内存并提升性能。
生成器的基本用法
生成器函数看起来像普通函数,但使用 yield 返回数据。每次调用生成器的 current() 或在 foreach 中迭代时,才会执行到下一个 yield。
function countUpTo($max) {
for ($i = 1; $i <= $max; $i++) {
yield $i;
}
}
// 使用生成器
foreach (countUpTo(5) as $number) {
echo $number . " ";
}
// 输出: 1 2 3 4 5
上面的例子中,数字是逐个产生的,不会把整个数组存入内存。
实现惰性加载大数据
当读取大文件或数据库大量记录时,使用生成器可以避免内存溢出。
立即学习“PHP免费学习笔记(深入)”;
function readLines($file) {
$handle = fopen($file, 'r');
if (!$handle) return;
while (($line = fgets($handle)) !== false) {
yield $line;
}
fclose($handle);
}
// 惰性读取每行
foreach (readLines('huge.log') as $line) {
echo "处理一行: " . trim($line) . "\n";
}
每一行只在需要时读取,内存中始终只保存一行内容。
生成器返回键值对
yield 可以指定键和值,适用于需要关联结构的场景。
function keyValueGen() {
yield 'a' => 1;
yield 'b' => 2;
yield 'c' => 3;
}
foreach (keyValueGen() as $key => $value) {
echo "$key: $value\n";
}
输出为:
a: 1
b: 2
c: 3
生成器的注意事项
生成器只能遍历一次,不能 rewind() 多次除非重新调用函数。也不能使用 count() 获取数量,因为它是按需执行的。
- 不要在生成器中使用 return 返回值(PHP 7.0+ 支持 return,但值通过 getReturn() 获取)
- yield 可以出现在表达式中,如:$data = (yield);
- 可嵌套多个生成器,用 yield from 继续委托
基本上就这些。生成器让 PHP 能优雅地处理流式数据,写起来简单,运行效率高,是实现惰性求值的理想方式。











