PHP生成器功能与用法实例分析
这篇文章主要介绍了PHP生成器功能与用法,结合实例形式分析了PHP生成器的概念、功能、使用方法及相关操作注意事项,需要的朋友可以参考下。
本文实例讲述了PHP生成器功能与用法,分享给大家供大家参考,具体如下:
1. 官方说明:生成器提供了一种更容易的方法来实现简单的对象迭代,相比较定义类实现 Iterator 接口的方式,性能开销和复杂性大大降低。生成器允许你在 foreach 代码块中写代码来迭代一组数据而不需要在内存中创建一个数组。
2. 生成器就像一个普通的自定义函数一样, 和普通函数只返回一次不同的是, 生成器可以根据需要 yield 多次,以便生成需要迭代的值。
3. 代码示例:
- //未使用生成器
- echo '开始内存:'.getMemory().'<br>';
- $nums = range(0,1000000);
- echo '结束内存:'.getMemory().'<br>';
- //输出结果
- //开始内存:0.23M
- //结束内存:130.31
- //使用生成器
- echo '开始内存:'.getMemory().'<br>';
- $nums = xrange(1000000);
- function xrange($total)
- {
- for ($i = 0; $i < $total; $i++) {
- yield $i;
- }
- }
- echo '结束内存:'.getMemory().'<br>';
- //输出结果
- //开始内存:0.23M
- //结束内存:0.23M
4. 实际应用示例
- /**
- * 大量数据生成示例
- * @param int $page
- * @param int $limit
- * @return Generator
- */
- public function generator($page = 1,$limit = 50000)
- {
- while (true) {
- echo "第{$page}次".'generator开始内存:'.$this->getMemory().'<br>';
- $start = ($page-1) * $limit;
- $sql = "SELECT p.id,p.wh_code,p.goods_sn FROM p_product as p WHERE p.wh_code LIKE '%YB%' OR p.wh_code LIKE '%DZWH%' LIMIT {$start},{$limit} ";
- $resultAll = db()->fetchAll($sql);
- yield $resultAll; //生成器
- if (count($resultAll) != $limit) {
- break;
- }
- echo "第{$page}次".'generator结束内存:'.$this->getMemory().'<br>';
- $page++;
- }
- }
- //测试生成器内存消耗
- // foreach ($this->generator() as $result) {
- // var_dump($result[0]);
- // }