Rumah > pembangunan bahagian belakang > tutorial php > 一个static 变量的递归

一个static 变量的递归

WBOY
Lepaskan: 2016-09-08 08:44:09
asal
1841 orang telah melayarinya

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

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

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

回复内容:

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

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

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

这是栈的入出顺序

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

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

Label berkaitan:
php
sumber:php.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan