When a reference is used in a foreach
loop instead of using a simple variable, the reference remains assigned and keeps its "value"
which is a reference, even after the foreach
execution. Most of the time, this is not what the developer is expecting and the reference
may be used wrongly in the rest of the code. For this reason, it is recommended to always unset
a reference that is used in a
foreach
to avoid any unexpected side effects.
Noncompliant Code Example
$arr = array(1, 2, 3);
foreach ($arr as &$value) { // Noncompliant; $value is still alive after the loop and references the last item of the array: $arr[2]
$value = $value * 2;
}
$value = 'x';
Compliant Solution
$arr = array(1, 2, 3);
foreach ($arr as &$value) { // Compliant; there is no risk to use by mistake the content of $value pointing to $arr[2]
$value = $value * 2;
}
unset($value);
$value = 'x';
See