<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的时候, 就不再进行递归了, 于是一层一层地完成递归操作
                        
                        每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
                Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号