|
$a = array(1, 2);
$b = array(11, 12);
foreach($a as &$r){
}
foreach($b as $r){
}
echo $a[1]; // 輸出 12
兩個的循環的本意可能是: 第一個循環需要在循環中修改元素的內容, 所以使用引用; 但第二個循環只是把 $r 當作一個臨時變量. 可是, 為什么 $a[1] 的值發生了改變呢?
當對 $a 的迭代完成后, $r 是 $a[1] 的引用, 改變 $r 的值, 就是改變 $a[1]. 這時, 你可以會奇怪, 代碼中并沒有修改 $r, 也沒有修改 $a[1] 呀?
其實, foreach 是操作的是數組的拷貝, 所以, 后一個迭代相當于:
復制代碼 代碼如下:
for($i=0; $i<count($b); $i++){
$r = $b[$i]; // 修改了 $r! 相當于 $a[1] = $b[$i];
}
為了避免這種情況, 應該在第一個迭代之后, 執行
復制代碼 代碼如下:
unset($r);
從當前環境中刪除 $r 這個變量(引用變量).
即使不是前面的例子, 在第一個迭代之后, 仍然十分可能再執行類似的語句:
復制代碼 代碼如下:
$r = 123;
循環變量一般是臨時變量, 同一個變量名在代碼不同的地方表示不同的東西, 但變量的作用域又存在于循環之外. 這就是這種作用域規則的壞處, 加上”變量不聲明即使用”的壞外, 再加上變量無類型的壞處.
所以, 在 php 中使用引用變量, 應該在引用使用完之后, 應該 unset(). 所有變量在使用之前應該先 unset().
php技術:PHP中使用foreach和引用導致程序BUG的問題介紹,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。