複製代碼 代碼如下:
$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$r = $b[$i]; // 修改了 $r! 相當於 $a[1] = $b[$i];
}
為了避免這種情況, 應該在第一個迭代之後, 執行
複製代碼 代碼如下:
unset($r);
從當前環境中刪除 $r 這個變數(引用變數).
即使不是前面的例子, 在第一個迭代之後, 仍然十分可能再執行類似的語句:
複製代碼 代碼如下:
$r = 123;
迴圈變數一般是臨時變數, 同一個變數名在代碼不同的地方表示不同的東西, 但變數的範圍又存在於迴圈之外. 這就是這種範圍規則的壞處, 加上”變數不聲明即使用”的壞外, 再加上變數無類型的壞處.
所以, 在 PHP 中使用引用變數, 應該在引用使用完之後, 應該 unset(). 所有變數在使用之前應該先 unset().
http://www.bkjia.com/PHPjc/325872.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/325872.htmlTechArticle複製代碼 代碼如下: $a = array(1, 2); $b = array(11, 12); foreach($a as // 輸出 12 兩個的迴圈的本意可能是: 第一個迴圈需要在迴圈中修改元素的內容...