一个static 变量的递归

WBOY
Libérer: 2016-09-08 08:44:09
original
1831 Les gens l'ont consulté

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

    echo $count++;
    if ($count < 10) {
        test();
    }
    echo $count--;
}
?></code>
Copier après la connexion
Copier après la connexion

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

回复内容:

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

    echo $count++;
    if ($count < 10) {
        test();
    }
    echo $count--;
}
?></code>
Copier après la connexion
Copier après la connexion

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

这是栈的入出顺序

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

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

Étiquettes associées:
php
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal