Rekursive Funktionen sind eine Art von Funktion, die wir häufig verwenden. Die grundlegendste Funktion besteht darin, dass die Funktion sich selbst aufruft. Sie muss jedoch vor dem Aufruf selbst bedingt beurteilt werden, da sie sonst auf unbestimmte Zeit aufgerufen wird. Mit welchen Methoden können rekursive Funktionen implementiert werden? In diesem Artikel werden drei grundlegende Möglichkeiten aufgeführt. Um es zu verstehen, ist ein gewisses Maß an Grundwissen erforderlich, einschließlich eines Verständnisses globaler Variablen, Referenzen, statischer Variablen und eines Verständnisses ihres Umfangs. Rekursive Funktionen sind auch eine gute Technik zur Lösung unendlicher Klassifizierungsebenen. Wenn Sie an einer unendlichen Klassifizierung interessiert sind, lesen Sie bitte PHP, um mithilfe rekursiver Funktionen eine unendliche Klassifizierung zu erreichen. Ich bin es gewohnt, komplexe Wahrheiten in Laienbegriffen zu erklären. Wenn Sie es wirklich nicht verstehen, schauen Sie bitte im Handbuch nach.
Referenzen als Parameter verwenden
Unabhängig davon, ob Referenzen Parameter sind oder nicht, müssen wir zunächst verstehen, was eine Referenz ist? Eine Referenz bedeutet einfach, dass zwei Variablen mit unterschiedlichen Namen auf dieselbe Speicheradresse verweisen. Ursprünglich hatte jede Variable ihre eigene Speicheradresse und das Zuweisen und Löschen verlief auf eigene Weise. Okay, jetzt teilen sich die beiden Variablen eine Speicheradresse. $a=&$b;. Was es tatsächlich bedeutet, ist, dass $a einen Raum mit $b teilen muss, unabhängig von seiner ursprünglichen Speicheradresse. Daher wirkt sich jede Änderung des gespeicherten Adresswerts auf beide Werte aus.
Funktionen erledigen ursprünglich ihre eigene Sache, auch wenn es sich um Funktionen mit demselben Namen handelt. Rekursive Funktionen berücksichtigen Referenzen als Parameter und werden zu einer Brücke, um den Datenaustausch zwischen zwei Funktionen zu bilden. Obwohl die beiden Funktionen scheinbar an unterschiedlichen Adressen arbeiten, arbeiten sie tatsächlich an derselben Speicheradresse.
<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>
Das obige Beispiel ist sehr einfach. Verwenden Sie $a<10 als Beurteilungsbedingung. Wenn die Bedingung wahr ist, legen Sie $a fest von $result Durch die Übergabe der Funktion wird $a, das bei jeder Rekursion generiert wird, zum Ergebnisarray $result hinzugefügt. Daher ist das in diesem Beispiel generierte $result-Array Array ( [0] => 1 [1] => 2 [2] => 3 [3] => 4 [4 ] = > 5 [5] => 6 [6] => 8 [8] => Was in diesem Beispiel interessanter ist, ist der Wert von echo $a. Ich glaube, viele Leute denken, es sei 12345678910, aber in Wirklichkeit ist es nicht so, es ist 1098765432. Warum? Weil die Funktion die nächste Funktionsrekursion durchgeführt hat, bevor sie echo $a ausführt. Die tatsächliche Ausführung von echo $a erfolgt, wenn die Bedingung $a<10 nicht erfüllt ist, echo $a gibt $result zurück. Für die obere Ebene wird nach Ausführung der rekursiven Funktion das echo $a dieser Ebene ausgeführt bald. Verwenden Sie globale Variablen Verwendung statischer Variablen Wir sehen oft statische Variablen in Klassen, heute verwenden wir sie in der Rekursivität Funktion. Denken Sie an die Rolle von Static: Initialisieren Sie die Variable nur beim ersten Aufruf der Funktion und behalten Sie den Variablenwert bei. Zum Beispiel: $count und behält $count nach jeder Ausführung bei wird nicht mehr initialisiert, was dem direkten Ignorieren des Satzes static$count=0; entspricht. Zusammenfassung
<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>
<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>