本文实例讲述了PHP生成器功能与用法。分享给大家供大家参考,具体如下:1.官方说明:生
本文实例讲述了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]);
// }
PHP
生成器