我遇到的情况是,foreach中的值通过引用传递以修改元素,然后在代码的后期阶段,相同的数组再次循环以进行一些计算,但这次是元素按值传递。问题是PHP保留了对第一个foreach中数组中最后一个元素的引用,然后当下一个foreach启动时覆盖该元素,如果局部变量具有相同的名称。
示例代码:
<?php
$a = array("a" => "foo");
$b = array("b" => "bar");
$x = array($a, $b);
foreach ($x as &$y) {}
print_r($x);
foreach ($x as $y) {}
print_r($x);
?>
这将产生
Array ( [0] => Array ( [a] => foo ) [1] => Array ( [b] => bar ) ) Array ( [0] => Array ( [a] => foo ) [1] => Array ( [a] => foo ) )
这种荒谬在PHP手册中说明
警告即使在foreach循环之后,也会引用$ value和最后一个数组元素。建议通过unset()来销毁它。
事实上,使用unset($y)
将解决问题。但这非常脆弱,你不能依赖编码器总是记住取消设置一个范围不明显的变量。所以我的问题是:foreach-by-reference是否有任何好的替代方法可以消除之后取消设置变量的需要?
答案 0 :(得分:3)
答案 1 :(得分:2)
您可以使用ASSOCIATIVE(索引)foreach:
foreach ($x as $index=>$y)
{
if ($y=='remove') {unset($x[$index]);}
}
这样您就可以轻松修改原始数组元素......