<?php
//比較打印99萬個數,那個快些。
//例1
var_dump(range(0, 999999));
//例2
function xrange($start, $limit, $step = 1)
{
//校驗參數,此處省略
for ($i = $start; $i <= $limit; $i += $step) {
//向外產出值
yield $i;
}
}
//xrange此時返回的是一個生成器對象
$gen = xrange(0, 9);
複製代碼
例1:在五個9的時候提示內存不夠用,報錯。
例2:在12個9的時候仍是能夠打印的。
比較結果: 這裏在xrange和range函數的效果相同,均是產生了一個可迭代的變量,可是不一樣的是,range函數有點像ORM裏面常說的 預加載 ,而xrange則是 懶加載 只是等到迭代到那個點纔會產生對應的值,所以xrange並不須要分配大塊內存來存放變量,大大節約了內存,提高效率。php
使用上面生產的$gen對象能夠調用到當前value、key、next等等; 詳見官方文檔https://www.php.net/manual/zh/class.generator.phpsegmentfault
//對生成器進行迭代
function xrange($start, $limit, $step = 1)
{
//校驗參數,此處省略
for ($i = $start; $i <= $limit; $i += $step) {
//向外產出值
yield $i;
}
}
//xrange此時返回的是一個生成器對象
$gen = xrange(0, 9);
//對生成器進行迭代
foreach ($gen as $number) {
echo $gen->key()."=>".$gen->current();
echo "</br>";
echo $gen->next();
}
//打印結果
0=>0
2=>2
4=>4
6=>6
8=>8
複製代碼
function count_to_ten()
{
yield 1;
yield 2;
yield from [3, 4]; //生成數組
yield from new ArrayIterator([5, 6]); //生成可遍歷對象
yield from seven_eight(); //生成生成器對象
yield 9;
yield 10;
}
function seven_eight()
{
yield 7;
yield from eight();
}
function eight()
{
yield 8;
}
foreach (count_to_ten() as $num) {
echo "$num ";
}
輸出:1 2 3 4 5 6 7 8 9 10
複製代碼
轉自:www.jianshu.com/p/e321c51df…數組
相見地址:segmentfault.com/a/119000001…bash