PHP生成器功能与用法实例分析

这篇文章主要介绍了PHP生成器功能与用法,结合实例形式分析了PHP生成器的概念、功能、使用方法及相关操作注意事项,需要的朋友可以参考下。

本文实例讲述了PHP生成器功能与用法,分享给大家供大家参考,具体如下:

1. 官方说明:生成器提供了一种更容易的方法来实现简单的对象迭代,相比较定义类实现 Iterator 接口的方式,性能开销和复杂性大大降低。生成器允许你在 foreach 代码块中写代码来迭代一组数据而不需要在内存中创建一个数组。

2. 生成器就像一个普通的自定义函数一样, 和普通函数只返回一次不同的是, 生成器可以根据需要 yield 多次,以便生成需要迭代的值。

3. 代码示例:

  1. //未使用生成器
  2. echo '开始内存:'.getMemory().'<br>';
  3. $nums = range(0,1000000);
  4. echo '结束内存:'.getMemory().'<br>';
  5. //输出结果
  6. //开始内存:0.23M
  7. //结束内存:130.31​
  8. //使用生成器
  9. echo '开始内存:'.getMemory().'<br>';
  10. $nums = xrange(1000000);
  11. function xrange($total)
  12. {
  13. for ($i = 0; $i < $total; $i++) {
  14. yield $i;
  15. }
  16. }
  17. echo '结束内存:'.getMemory().'<br>';
  18. //输出结果
  19. //开始内存:0.23M
  20. //结束内存:0.23M

4. 实际应用示例

  1. /**
  2. * 大量数据生成示例
  3. * @param int $page
  4. * @param int $limit
  5. * @return Generator
  6. */
  7. public function generator($page = 1,$limit = 50000)
  8. {
  9. while (true) {
  10. echo "第{$page}次".'generator开始内存:'.$this->getMemory().'<br>';
  11. $start = ($page-1) * $limit;
  12. $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} ";
  13. $resultAll = db()->fetchAll($sql);
  14. yield $resultAll; //生成器​
  15. if (count($resultAll) != $limit) {
  16. break;
  17. }
  18. echo "第{$page}次".'generator结束内存:'.$this->getMemory().'<br>';
  19. $page++;
  20. }
  21. }
  22. //测试生成器内存消耗
  23. // foreach ($this->generator() as $result) {
  24. // var_dump($result[0]);
  25. // }