生成器比数组更适合内存敏感、流式响应和大数据场景。它按需产出数据,避免内存溢出,适用于数据库遍历、日志处理、动态序列、sse输出及函数组合等,但不可重用且调试需特殊方法。

当处理大量数据、内存敏感或需要流式响应时,生成器比数组更合适。它不一次性加载全部数据到内存,而是按需产出,节省资源并提升响应速度。
大数据集遍历(如数据库查询结果)
从数据库读取数万行记录时,用 Array 会把所有结果一次性载入内存,容易触发内存溢出;而生成器可逐条 yield,保持内存占用稳定。
- 使用 pdo 的
fetch()配合yield,每次只保留当前行 - 避免
fetchAll(),尤其在分页或导出场景中 - 示例:读取日志文件逐行处理,每行 yield 一次,不加载整个文件
无限或动态序列生成
斐波那契数列、时间范围迭代、ID 流等无法预知长度的场景,数组无法预先定义大小,生成器天然适配。
API 响应流式输出(SSE / 分块传输)
构建实时通知、大文件下载或长耗时任务进度推送时,需边处理边发送,数组必须等全部完成才能返回。
立即学习“PHP免费学习笔记(深入)”;
函数组合与中间件式数据处理
多个过滤、转换逻辑串联时,用生成器可实现“懒执行”,避免中间数组拷贝和冗余内存分配。
- 例如:
Filter($data)→map($data)→limit($data, 10),每个环节都是生成器 - 最终 foreach 时才真正触发整条链路,且只计算所需项
- 比 array_map + array_filter + array_slice 组合更省内存、更易调试
不复杂但容易忽略:生成器不可重用,每次需重新调用生成器函数;调试时不能直接 var_dump,要用 iterator_to_array() 或循环查看。合理权衡可维护性与性能,小数据量仍推荐数组——简洁即优势。