Fonctions PHP récursives anonymes : démystifiées
Dans le domaine du développement PHP, la question de la création de fonctions récursives anonymes se pose souvent. Une fonction anonyme est essentiellement une fermeture dépourvue de nom dédié et définie dans le corps d’une autre fonction. La récursivité, quant à elle, est une technique dans laquelle une fonction s'appelle elle-même selon sa propre définition, permettant la solution itérative de problèmes complexes.
Considérez cette tentative de fonction récursive anonyme :
<code class="php">$factorial = function( $n ) use ( $factorial ) { if( $n <= 1 ) return 1; return $factorial( $n - 1 ) * $n; }; print $factorial( 5 );</code>
Cependant, comme on peut le remarquer, cette implémentation ne parvient pas à transmettre le nom de la fonction à l'appel récursif. Pour remédier à ce problème, nous introduisons le concept de passage de la fonction anonyme par référence :
<code class="php">$factorial = function( $n ) use ( &$factorial ) { if( $n == 1 ) return 1; return $factorial( $n - 1 ) * $n; }; print $factorial( 5 );</code>
En passant la variable $factorial par référence (c'est-à-dire en utilisant le symbole &), nous nous assurons que la fonction anonyme peut accéder à la valeur de la variable d'origine et la modifier en conséquence. Cela permet des appels récursifs réussis au sein de la fonction anonyme, ouvrant la voie à des possibilités intrigantes dans le développement PHP.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!