ホームページ >バックエンド開発 >PHPチュートリアル >PHP 再帰関数を実装する 3 つの方法
再帰関数は、私たちがよく使う関数の一種で、最も基本的な特徴は、関数がそれ自体を呼び出すことですが、それを呼び出す前に条件付きで判定する必要があり、そうしないと無限に呼び出され続けます。再帰関数を実装するにはどのような方法を使用できますか?この記事では 3 つの基本的な方法を示します。これを理解するには、グローバル変数、参照、静的変数の理解、およびそれらのスコープの理解など、ある程度の基本的な知識が必要です。再帰関数は、無限レベルの分類を解決するための優れた手法でもあります。無限分類に興味がある場合は、PHP を参照して再帰関数を使用して無限分類を実現してください。複雑な真実を平易な言葉で説明することに慣れています。本当に理解できない場合は、マニュアルを参照してください。
パラメータとして参照を使用する
参照がパラメータであるかどうかに関係なく、まず参照とは何かを理解する必要があります。参照とは、単に、異なる名前を持つ 2 つの変数が同じ記憶アドレスを指していることを意味します。元々、各変数には独自の格納アドレスがあり、代入と削除は独自の方法で行われました。さて、2 つの変数はストレージ アドレスを共有します。 $a=&$b;。これが実際に意味するのは、元のストレージ アドレスに関係なく、$a は $b とルームを共有しなければならないということです。したがって、保存されているアドレス値を変更すると、両方の値に影響します。
関数は、同じ名前の関数であっても、本来は独自の処理を行います。再帰関数は、参照をパラメータとして受け取り、2 つの関数間でデータ共有を形成するためのブリッジになることを考慮します。 2 つの関数は異なるアドレスで動作しているように見えますが、実際には同じメモリ アドレスで動作します。
<span>function</span> test(<span>$a</span>=0,&<span>$result</span>=<span>array</span><span>()){ </span><span>$a</span>++<span>; </span><span>if</span> (<span>$a</span><10<span>) { </span><span>$result</span>[]=<span>$a</span><span>; test(</span><span>$a</span>,<span>$result</span><span>); }<br />echo $a; </span><span>return</span><span>$result</span><span>; }</span>
上記の例は非常に単純で、条件が true の場合は $a<10 を $result[] に代入し、各再帰を生成します。 $a を結果配列 $result に追加します。したがって、この例で生成される $result 配列は Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4] => となります。 5 [5] => 6 [6] => 8 [8] => 9 この例でさらに興味深いのは、echo $a の値です。 12345678910だと思っている人も多いと思いますが、実はそうではなく、1098765432です。なぜ?これは、関数が echo $a を実行する前に次の関数の再帰を実行しているためです。 echo $a の実際の実行は、条件 $a グローバル変数を使用する 静的変数の使用 静的変数はクラスでよく見ますが、今日では再帰関数で使用します。 static の役割を覚えておいてください。関数が最初に呼び出されたときにのみ変数を初期化し、変数値を保持します。 例をあげてください: $count を初期化します。各実行後、$count の値は保持され、初期化されなくなります。これは、直接無視するのと同じです。 static $count=0; この文。 概要
<span>function</span> test(<span>$a</span>=0,<span>$result</span>=<span>array</span><span>()){
</span><span>global</span><span>$result</span><span>;
</span><span>$a</span>++<span>;
</span><span>if</span> (<span>$a</span><10<span>) {
</span><span>$result</span>[]=<span>$a</span><span>;
test(</span><span>$a,$result</span><span>);
}
</span><span>return</span><span>$result</span><span>;
}</span>
<span>function</span><span> test(){
</span><span>static</span><span>$count</span>=0<span>;
</span><span>echo</span><span>$count</span><span>;
</span><span>$count</span>++<span>;
}
test();
test();
test();
test();
test();</span>
このコードの実行結果は何ですか? 00000ですか?絶対にありません。 01234です。まず、test() を初めて呼び出して <span>function</span> test(<span>$a</span>=0<span>){
</span><span>static</span><span>$result</span>=<span>array</span><span>();
</span><span>$a</span>++<span>;
</span><span>if</span> (<span>$a</span><10<span>) {
</span><span>$result</span>[]=<span>$a</span><span>;
test(</span><span>$a</span><span>);
}
</span><span>return</span><span>$result</span><span>;
}</span>
<span>function</span> test(<span>$a</span>=0<span>){
</span><span>$a</span>++<span>;
</span><span>if</span> (<span>$a</span><10<span>) {
</span><span>echo</span><span>$a</span><span>;
test(</span><span>$a</span><span>);
}
}</span>
このような関数に直面しても、それについて心配する必要はありません。ちなみに、変数参照を深く理解していれば、この種の問題を解決するのに大いに役立ちます。