结论: foreach($arr as &$v) 类似这样的引用循环, 脚本语言需要注意,再次使用 $v时,他还指向原来的引用。会产生问题。
unset($v)可以解除引用。
所以循环引用过滤数据也要需要特别注意。
类似如下。
foreach ($cameraList as $key => &$value) {
unset($value); // 不能删除值 只是解除引用
unset($cameraList[$key]) // 删除了cameraList数组里面满足条件的值
}
转: https://www.cnblogs.com/sailrancho/p/4655345.html
<?php $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')。