本文實例講述了PHP生成器功能與用法。分享給大家供大家參考,具體如下:
1. 官方說明:生成器提供了一種更容易的方法來實現(xiàn)簡單的對象迭代,相比較定義類實現(xiàn) Iterator 接口的方式,性能開銷和復雜性大大降低。生成器允許你在 foreach 代碼塊中寫代碼來迭代一組數(shù)據(jù)而不需要在內存中創(chuàng)建一個數(shù)組。
2. 生成器就像一個普通的自定義函數(shù)一樣, 和普通函數(shù)只返回一次不同的是, 生成器可以根據(jù)需要 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. 實際應用示例
/** * 大量數(shù)據(jù)生成示例 * @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相關內容感興趣的讀者可查看本站專題:《php常用函數(shù)與技巧總結》、《php字符串(string)用法總結》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結構與算法教程》及《php程序設計算法總結》
希望本文所述對大家PHP程序設計有所幫助。