復制代碼 代碼如下:
$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().