PHP生成器使用步骤详解

php中世界最好的语言
풀어 주다: 2023-03-26 13:26:01
원래의
1350명이 탐색했습니다.

这次给大家带来PHP生成器使用步骤详解,PHP生成器使用的注意事项有哪些,下面就是实战案例,一起来看一下。

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

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

3. 代码示例:

//未使用生成器
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
로그인 후 복사

4. 实际应用示例

/**
 * 大量数据生成示例
 * @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]); //    }
로그인 후 복사

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

PHP实现单向散列加密操作步骤详解

PHP隐藏入口文件步骤详解

PECL方式安装php-mongodb扩展步骤详解

위 내용은 PHP生成器使用步骤详解의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!