Heim >Backend-Entwicklung >PHP-Tutorial >## Können PHP-Funktionen rekursiv anonym sein? Ein tiefer Einblick in Funktionsreferenzen und Rekursion.
Können PHP-Funktionen rekursiv anonym sein?
In PHP hat die Möglichkeit, eine Funktion zu erstellen, die sowohl rekursiv als auch anonym ist, Programmierer verwirrt. Diese Frage stellt sich aufgrund der typischen Verwendung von Funktionsnamen für die Rekursion. Wie das bereitgestellte Beispiel zeigt, kann jedoch tatsächlich eine rekursive anonyme Funktion in PHP implementiert werden.
Der bereitgestellte Code, der versucht, die Fakultät einer Zahl mithilfe der Rekursion innerhalb einer anonymen Funktion zu berechnen, steht bei der Übergabe vor einer Herausforderung der Funktionsname. Um dieses Problem zu beheben, ist es wichtig, die Funktion als Referenz zu übergeben. Durch Hinzufügen eines kaufmännischen Und (&) vor $factorial in der use-Anweisung wird die Funktion selbst innerhalb der anonymen Funktion verfügbar.
Hier ist der geänderte Code:
<code class="php">$factorial = function( $n ) use ( &$factorial ) { if( $n == 1 ) return 1; return $factorial( $n - 1 ) * $n; }; print $factorial( 5 );</code>
Mit dieser Änderung wird die Die Funktion $factorial kann nun rekursiv auf sich selbst verweisen, sodass die gewünschte Fakultätsberechnung korrekt funktioniert.
Das obige ist der detaillierte Inhalt von## Können PHP-Funktionen rekursiv anonym sein? Ein tiefer Einblick in Funktionsreferenzen und Rekursion.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!