在第一个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。
运行第一个循环时,我们看到以下输出:
fooArray ( [0] => foo [1] => bar [2] => baz )barArray ( [0] => foo [1] => bar [2] => baz )bazArray ( [0] => foo [1] => bar [2] => baz )
在循环结束时,
$item仍指向与相同的位置
$arr[2]。
当第二个循环运行时,我们看到以下输出:
fooArray ( [0] => foo [1] => bar [2] => foo )barArray ( [0] => foo [1] => bar [2] => bar )barArray ( [0] => foo [1] => bar [2] => bar )
您会注意到每个时间数组如何将一个新值放入中
$item,它也
$arr[3]使用相同的值进行更新,因为它们都仍指向相同的位置。当循环到达数组的第三个值时,它将包含该值,
bar因为它只是由该循环的上一次迭代设置的。是虫子吗?
否。这是引用项目的行为,而不是错误。这类似于运行类似的内容:
for ($i = 0; $i < count($arr); $i++) { $item = $arr[$i]; }
foreach循环本质上并不特殊,它可以忽略引用的项目。就像在循环外一样,每次都只是将变量设置为新值。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)