<?php
$a = array(
'str1' => 'val1',
'str2' => 'val2',
'str3' => 'val3',
'str4' => 'val4',
);
$b = array(
'str1',
'str2',
'str3',
'str4',
);
foreach ($b as &$val) {
$val = $a[$val];
}
unset($val);
foreach ($b as $val) {
echo "-----$b[3]";
echo $val."\n";
}
?></pre><br>
<?php$a = array('str1' => 'val1','str2' => 'val2','str3' => 'val3','str4' => 'val4',);$b = array('str1', 'str2','str3','str4',);foreach ($b as &$val) {$val = $a[$val];}foreach ($b as $val) {echo "-----$b[3]";echo $val."\n";}?>
<p>输出:</p>
<p>-----val1val1<br>
-----val2val2<br>
-----val3val3<br>
-----val3val3</p>
<p> </p>
<p><br>
</p>
<p>可以看到,因为第一个foreach 的引用最后的$[2] 引用没有关闭,所以,在第二个foreach 中已然在不断的对地址进行写操作;</p>
<p> </p>
<p>通过打印$b[2] 的值,可以看出。随着foreach 的运行,$b[2] 的值在不断的改变。这就导致当foreach 运行到$b[1] 的时候,$b[2] 的值</p>
<p> </p>
<p>就等于$b[1], 那么在最后一次运行时,$b[2] = $b[2] 就是的结果与$b[1] 一样了</p>
<p> </p>
<p> </p>
<p>解决方案:</p>
<p>使用unset () 方法将引用变量释放后再进行第二次foreach 循环。</p>
<p> </p>
<pre class="php" name="code"><?php
$a = array(
'str1' => 'val1',
'str2' => 'val2',
'str3' => 'val3',
'str4' => 'val4',
);
$b = array(
'str1',
'str2',
'str3',
'str4',
);
foreach ($b as &$val) {
$val = $a[$val];
}
unset($val);
foreach ($b as $val) {
echo "-----$b[3]";
echo $val."\n";
}
?></pre>
<p><br>
输出结果:</p>
<p>-----val4val1<br>
-----val4val2<br>
-----val4val3<br>
-----val4val4</p>
<p> </p>
<p> </p>
<p>方案二(不怎么好):</p>
<p> </p>
<p> </p>
<pre class="php" name="code"><?php
$a = array(
'str1' => 'val1',
'str2' => 'val2',
'str3' => 'val3',
'str4' => 'val4',
);
$b = array(
'str1',
'str2',
'str3',
'str4',
);
foreach ($b as &$val) {
$val = $a[$val];
}
// unset($val);
foreach ($b as $item) {
echo "-----$b[3]";
echo $item."\n";
}
?></pre>
<p> </p>
<p>换掉第二次foreach 中的as 后的变量,不使用被引用的变量,那么不会出现这样的情况。</p>
<p>输出:</p>
<p>-----val4val1<br>
-----val4val2<br>
-----val4val3<br>
-----val4val4<br>
</p>
<p> </p>
<p>总结: 建议在引用之后使用unset() 对其释放。</p>
<p> </p>
PHP foreach 的用法
最新推荐文章于 2024-07-28 08:43:29 发布