$arr = array('a', 'b', 'c');
foreach($arr as &$v) {}
foreach($arr as $v) {}
var_dump($arr);
结果为:
array(3) {
[0]=>
string(1) "a"
[1]=>
string(1) "b"
[2]=>
&string(1) "b"
}
第一个foreach用引用赋值的方式将数组的值依次赋给了$v。
$arr = array('a', 'b', 'c');
foreach($arr as &$v) {}
var_dump($v);
此时的$v的值为c,是引用赋值,$v指向了字符串c的地址空间。
第二个foreach是以拷贝赋值的方式将数组的值依次赋值给了$v。
由于目前$v指向了c的地址空间,那么改变$v的值即改变了c所占地址空间的值。
$arr = array('a', 'b', 'c');
foreach($arr as &$v) {}
foreach($arr as $v) {
var_dump($arr); break;
}
第一次赋值将a赋值到了$v,原有c所占的地址空间的值变为了a,此时数组就是array('a', 'b', 'a')。
以此类推第一次赋值c->a,第二次赋值即a->b,第三次赋值即b->b,
所以最终结果为array('a', 'b', 'b')。
解决方案是永远不要用&
或者老老实实按照官网的指示,用unset解除引用
引用结束后 unset($v); 就没问题了