首頁 > 後端開發 > php教程 > 递归函数里有foreach数组的时候,数组是如何被遍历的?

递归函数里有foreach数组的时候,数组是如何被遍历的?

WBOY
發布: 2016-06-13 12:03:43
原創
1147 人瀏覽過

递归函数里有foreach数组的时候,数组是怎么被遍历的??
$arr = Array(Array('a1','a2'),Array('b1','b2'),Array('c1','c2'));
function tree($a){
    foreach($a as $row){

    tree($a);
    }
}
tree($a);
这样的代码,在函数体里面tree($a);递归的时候,它是从数组里第一个元素Array('a1','a2')重新开始遍历吗
当第一层的foreach遍历到第二个元素,又一次tree($a);递归的时候,也是从第一个元素Array('a1','a2')重新开始遍历吗??
------解决方案--------------------
你这个递归都死循环了,会溢出的。。。
------解决方案--------------------

$arr = Array(Array('a1','a2'),Array('b1','b2'),Array('c1','c2'));<br />function tree($a){<br />  foreach($a as $row){	<br />    if(is_array($row)) tree($row);<br />    else echo $row . '<br>';<br />  }<br />}<br />tree($arr);<br />
登入後複製
a1
a2
b1
b2
c1
c2

------解决方案--------------------
你的递归没有结束条件,会死循环。
结束条件是,如果元素不是数组则不需要递归了。

<br />$arr = Array(Array('a1','a2'),Array('b1','b2'),Array('c1','c2'));<br />function tree($a){<br />    if(is_array($a)){ // 这里判断是否需要再递归<br />        foreach($a as $row){<br />            tree($row);<br />        }<br />    }else{<br />        echo $a.'<br>';<br />    }<br />}<br />tree($arr);<br />
登入後複製

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板