<code>$a = [ "a"=>["cc"=>11] , "b"=>["cc"=>22] ];
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
$i=1;
//(1)拷贝,$a无变化
foreach($a as $k=>$v) {
$v['cc']=$i;
$i+=1;
}
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
//(2)引用
foreach($a as $k=>&$v) {
$v['cc']=$i;
$i+=1;
}
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
//(3)拷贝
foreach($a as $k=>$v) {
$a[$k]["cc"]=$i;
$i+=1;
}
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
</code>默认foreach是拷贝数组,需要两倍的内存,那性能是不是会很低啊?为什么要这么设计呢
如果数组非常大的情况下,是不是用引用方式会好一些?各自有什么优缺点?
<code>$a = [ "a"=>["cc"=>11] , "b"=>["cc"=>22] ];
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
$i=1;
//(1)拷贝,$a无变化
foreach($a as $k=>$v) {
$v['cc']=$i;
$i+=1;
}
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
//(2)引用
foreach($a as $k=>&$v) {
$v['cc']=$i;
$i+=1;
}
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
//(3)拷贝
foreach($a as $k=>$v) {
$a[$k]["cc"]=$i;
$i+=1;
}
echo "\n".$a['a']["cc"].",".$a['b']["cc"];
</code>默认foreach是拷贝数组,需要两倍的内存,那性能是不是会很低啊?为什么要这么设计呢
如果数组非常大的情况下,是不是用引用方式会好一些?各自有什么优缺点?
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号