PHP生成器功能与用法实例分析
php  /  管理员 发布于 7年前   238
本文实例讲述了PHP生成器功能与用法。分享给大家供大家参考,具体如下: 1. 官方说明:生成器提供了一种更容易的方法来实现简单的对象迭代,相比较定义类实现 Iterator 接口的方式,性能开销和复杂性大大降低。生成器允许你在 foreach 代码块中写代码来迭代一组数据而不需要在内存中创建一个数组。 2. 生成器就像一个普通的自定义函数一样, 和普通函数只返回一次不同的是, 生成器可以根据需要 yield 多次,以便生成需要迭代的值。 3. 代码示例: 4. 实际应用示例 更多关于PHP相关内容感兴趣的读者可查看本站专题:《php常用函数与技巧总结》、《php字符串(string)用法总结》、《PHP数组(Array)操作技巧大全》、《PHP数据结构与算法教程》及《php程序设计算法总结》 希望本文所述对大家PHP程序设计有所帮助。//未使用生成器echo '开始内存:'.getMemory().'
';$nums = range(0,1000000);echo '结束内存:'.getMemory().'
';//输出结果//开始内存:0.23M//结束内存:130.31//使用生成器echo '开始内存:'.getMemory().'
';$nums = xrange(1000000);function xrange($total){ for ($i = 0; $i < $total; $i++) { yield $i; }}echo '结束内存:'.getMemory().'
';//输出结果//开始内存:0.23M//结束内存:0.23M/** * 大量数据生成示例 * @param int $page * @param int $limit * @return Generator */public function generator($page = 1,$limit = 50000){ while (true) { echo "第{$page}次".'generator开始内存:'.$this->getMemory().'
'; $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().'
'; $page++; }} //测试生成器内存消耗// foreach ($this->generator() as $result) {// var_dump($result[0]);// }您可能感兴趣的文章:
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号