小编典典
在第一个foreach循环之后,$item仍然是对的引用,该值也被所使用$arr[2]。因此,第二个循环中的每个foreach调用(不是通过引用调用)都会替换该值,并因此替换$arr[2]为新值。
因此,循环1的值$arr[2]变成了$arr[0]‘foo’。
循环2,值和$arr[2]变为$arr[1],即“ bar”。
循环3的值和$arr[2]变为$arr[2]‘bar’(由于循环2)。
实际上,在第二个foreach循环的第一次调用中,值“ baz”实际上丢失了。
调试输出
对于循环的每次迭代,我们将回显的值,$item并递归地打印array $arr。
运行第一个循环时,我们看到以下输出:
foo
Array ( [0] => foo [1] => bar [2] => baz )
bar
Array ( [0] => foo [1] => bar [2] => baz )
baz
Array ( [0] => foo [1] => bar [2] => baz )
在循环结束时,$item仍指向与相同的位置$arr[2]。
当第二个循环运行时,我们看到以下输出:
foo
Array ( [0] => foo [1] => bar [2] => foo )
bar
Array ( [0] => foo [1] => bar [2] => bar )
bar
Array ( [0] => foo [1] => bar [2] => bar )
您会注意到每个时间数组如何将一个新值放入中$item,它也$arr[3]使用相同的值进行更新,因为它们都仍指向相同的位置。当循环到达数组的第三个值时,它将包含该值,bar因为它只是由该循环的上一次迭代设置的。
是虫子吗?
否。这是引用项目的行为,而不是错误。这类似于运行类似的内容:
for ($i = 0; $i < count($arr); $i++) { $item = $arr[$i]; }
foreach循环本质上并不特殊,它可以忽略引用的项目。就像在循环外一样,每次都只是将变量设置为新值。
2020-05-26