<?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