Maison  >  Article  >  développement back-end  >  一个static 变量的递归

一个static 变量的递归

WBOY
WBOYoriginal
2016-09-08 08:44:091829parcourir

<code class="php"><?php function test()
{
    static $count = 0;

    echo $count++;
    if ($count < 10) {
        test();
    }
    echo $count--;
}
?></code>

结果:012345678910987654321
前上半的echo $cont++,我能理解,为什么echo $count--他是从10开始的。按从上到下,++ --不抵消了吗

回复内容:

<code class="php"><?php function test()
{
    static $count = 0;

    echo $count++;
    if ($count < 10) {
        test();
    }
    echo $count--;
}
?></code>

结果:012345678910987654321
前上半的echo $cont++,我能理解,为什么echo $count--他是从10开始的。按从上到下,++ --不抵消了吗

这是栈的入出顺序

if 里面调用了函数, 下面的是执行不了的,直到count>10 函数调用结束,后面才能执行。

前10次递归是没有执行echo $count--;的, 因为递归调用还没有结束. 直到 $count == 10的时候, 就不再进行递归了, 于是一层一层地完成递归操作

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn