看PHP手册的时候发现了下面这样一段代码:
复制代码 代码如下:
function Test()
{
static $count = 0;
$count++;
echo $count;
if ($count < 10) {
Test();
}
$count--;
}
?>
执行结果如下:
这是一个递归的函数,声明的静态变量count记录次数,输出1~10。
我在看的时候有个疑惑,递归调用的时候 static $count = 0; 语句会重复执行,这为什么不会导致count变量被重复赋值呢?带着这个疑问和同事研究了一下,测试用代码如下:
复制代码 代码如下:
echo 'start
';
static $a = 10;
echo "$a
";
unset($GLOBALS['a']);
echo "$a
";
static $a = 20;
echo "$a
";
$GLOBALS['a'] = 10;
echo "$a
";
static $a = 30;
echo "$a
";
unset($GLOBALS['a']);
echo "$a
";
static $a;
echo "$a
";
static $a = 40;
echo "$a
";
$a = 100;
echo "$a
";
static $a = 50;
echo "$a
";
static $a = 4;
echo "$a
";
echo 'end
';
exit;
?>
执行结果如下:
start
-
4
-
Notice: Undefined variable: a
-
4
-
10
-
10
-
Notice: Undefined variable: a
-
10
-
10
-
100
-
100
-
100
-
end
(结果中关于文件位置的部分已删去。也可以去掉echo语句使用zend的debug功能查看,这样结果更清晰)
代码第5行第一次输出$a的值为4,由此推测PHP在页面初始化的时候分配静态变量的内存,此时使用了同一个变量的最后一次声明的值(这个可以把4改为其他数测试)。代码第7行调用unset函数销毁变量$a,再次输出$a的值时看到未定义变量的提示,说明变量已经被销毁。
行 10 が再度出力されると、出力結果は 20 ではなく 4 のままです。 1 つは PHP が $a の値を再度初期化すること、もう 1 つは PHP が前に $a を使用することです。値が破壊されている場合、この問題は 20 行目に出力すると解決されます。 $a の値は 16 行目で破棄されたときは 10 ですが、19 行目で宣言された後も出力は 10 のままです。
11行目で$aの値を10に変更し、14行目で再度$aを宣言し、17行目で10として出力します。宣言が繰り返された場合、PHP は静的変数メモリ内の値を再割り当てせずに引き続き使用すると推測されます。
この時点で、マニュアルで見つかった問題は大まかに解決されました。つまり、再帰呼び出し内のステートメントは $count の値を変更しなかったため、$count=10 で再帰が正常に停止しました。
間違った理解があるかもしれませんので、コメントしてください。