在php5.5以前,使用foreach循环一个数组时,这个数组是实实在在存在内存中的,所以当你需要循环一个大的数组的时候,有可能会占很大内存,当人我们希望这样。php5.5实现了生成器来解决这种东西。
例子:我们现在要循环一个range函数生成的数组,按照之前的做法:
先生成一个有1000000个元素的数组放在内存中,然后再遍历这个数组,这样就占用了超过100MB的内存(php手册上的说法);
现在,在使用生成器实现:
上面这句代码执行过程是这样的:当把generage_range()函数赋值给$range变量的时候,并没有执行该函数,而是返回一个对象,赋值给$range。当后面foreach的时候,才开始执行函数,并且遍历一次,就执行一次generate_range(),在每次执行函数时,执行到关键字yield便停止执行,然后yield返回$i值,并记录下当前执行状态,下次执行的时候,便从yield下一句开始执行,然后知道结束。可以看出,这样做的话每次只保存一个元素,所以内存占用量大幅度减少。
例子:我们现在要循环一个range函数生成的数组,按照之前的做法:
$array=range(1,1000000);
foreach ($array as $number) {
echo $number;
}
先生成一个有1000000个元素的数组放在内存中,然后再遍历这个数组,这样就占用了超过100MB的内存(php手册上的说法);
现在,在使用生成器实现:
function generate_range(){
for($i=1;$i<=1000000;++$i){
yield $i;
}
}
$range=generage_range();
foreach($range as $v){
echo $v;
}
上面这句代码执行过程是这样的:当把generage_range()函数赋值给$range变量的时候,并没有执行该函数,而是返回一个对象,赋值给$range。当后面foreach的时候,才开始执行函数,并且遍历一次,就执行一次generate_range(),在每次执行函数时,执行到关键字yield便停止执行,然后yield返回$i值,并记录下当前执行状态,下次执行的时候,便从yield下一句开始执行,然后知道结束。可以看出,这样做的话每次只保存一个元素,所以内存占用量大幅度减少。