Heim Backend-Entwicklung PHP-Tutorial Detaillierte Erläuterung des Funktionsmechanismus und Beispiele der Rekursion in PHP

Detaillierte Erläuterung des Funktionsmechanismus und Beispiele der Rekursion in PHP

Feb 05, 2018 am 10:15 AM
php 详解 运行机制

PHP-Rekursion ist ein Mechanismus, bei dem sich eine Funktion selbst aufruft (direkt oder indirekt). Diese leistungsstarke Idee kann einige komplexe Konzepte extrem einfach machen. Dieser Artikel stellt hauptsächlich die detaillierten Implementierungsbeispiele der Rekursion in PHP vor. Freunde, die nicht viel über Rekursion in PHP wissen, können auf diesen Artikel verweisen

Die Definition der Rekursion

Rekursion ist ein Mechanismus, mit dem sich eine Funktion (direkt oder indirekt) selbst aufrufen kann. Diese leistungsstarke Idee kann einige komplexe Konzepte extrem einfach machen. Außerhalb der Informatik, insbesondere in der Mathematik, ist der Begriff der Rekursion weit verbreitet. Zum Beispiel: Die Fibonacci-Folge, die am häufigsten zur Erklärung der Rekursion verwendet wird, ist ein sehr typisches Beispiel, und andere wie Hierarchie (n!) können auch in rekursive Definitionen umgewandelt werden (n! = n*(n-1)! ) Auch im wirklichen Leben ist rekursives Denken überall zu beobachten: Aufgrund akademischer Probleme braucht man beispielsweise das Siegel des Schulleiters, aber der Schulleiter sagt: „Ich werde es nur stempeln, wenn der Dekan es gestempelt hat.“ der Dekan, der Lehrer Der Direktor sagte auch: „Ich werde es nur stempeln, wenn es vom Dekan der Abteilung gestempelt wird.“... Bis Sie endlich den Schulleiter finden und nachdem Sie den großzügigen Stempel vom Schulleiter erhalten haben, Sie müssen zum Abteilungsleiter, zum Dekan und schließlich zum Schulleiter zurückkehren. Der Vorgang ist wie folgt:

Eine rekursive Funktion ist eine Funktion, die sich selbst aufruft. Seien Sie beim Schreiben rekursiver Funktionen vorsichtig, da diese möglicherweise auf unbestimmte Zeit rekursiv sind. Sie müssen sicherstellen, dass geeignete Mittel zum Beenden der Rekursion vorhanden sind.

1: Verwenden Sie die Parameterreferenz, um die rekursive Funktion abzuschließen. Die Operation ist dieselbe Speicheradresse.

<?php
$i=1; 
function test(&$i) 
{
echo $i; 
$i++; 
 if ($i < 10) 
{ 
test($i);
} 
} 
test($i);// 输出123456789
test ( $i );// 输出10
?>
Nach dem Login kopieren


Zweitens: Verwenden Sie globale Variablen, um die rekursive Funktion abzuschließen.

Eine echte globale Variable, die mit der globalen Anweisung innerhalb der Funktionsdomäne importiert wird, stellt tatsächlich einen Verweis auf die globale Variable her. Im Beispiel ist $i innerhalb der Funktion test() eigentlich nur eine Anwendung der Variablen $i in der ersten Zeile des Programms ($i = 1;); 🎜>drei: Verwenden Sie statische Variablen, um rekursive Funktionen abzuschließen.

<?php 
$i = 1 ;
function test ()
{ 
global $i ;
 echo $i ;
$i++; 
 if ($i <10 ) 
{ 
test();
} 
} 
test();// 输出123456789
test ();// 输出10
?>
Nach dem Login kopieren

Die Rolle von Statik: Initialisieren Sie die Variable nur, wenn die Funktion zum ersten Mal aufgerufen wird, und behalten Sie den Variablenwert bei. Beispiel 1. Rekursive Durchquerung mit globalen Variablen

Alle Dateien im Ordner durchsuchen

<?php 
function test () 
{ 
  static $i = 1 ; 
  echo $i ;
$i ++; 
  if ( $i < 10 ) { 
     test ();
  } 
  $i --;// 在每一层递归结束时自减,这一句可以帮助理解递归函数的执行过程 
}
test();// 输出123456789
test();// 输出123456789 
?>
Nach dem Login kopieren

Beispiel 2: Rekursive Durchquerung mit statischen Variablen Alle Dateien im Ordner

function getFiles($dir)
{
global $arr;
if(is_dir($dir)){
$hadle = @opendir($dir);
while($file=readdir($hadle) )
{
if(!in_array($file,array(&#39;.&#39;, &#39;..&#39;)) )
{
$dirr = $dir.&#39;/&#39;.$file;
if(is_dir($dirr))
{
getFiles($dirr);
}else{
array_push($arr, $dirr);
}
}
}
}
}
$arr = array();
getFiles(&#39;E:/logs&#39;);
print_r($arr);
Nach dem Login kopieren

Zusammenfassung

function getFiles ($dir)
{
static $arr = array();
if(is_dir($dir)){
$hadle = opendir($dir);
while($file=readdir($hadle))
{
if(!in_array($file,array(&#39;.&#39;,&#39;..&#39;)) )
{
$dirr = $dir."/".$file;
if(is_dir($dirr))
{
getFiles ($dirr);
}else{
array_push($arr,$dirr);
}
}
}
}
return $arr;
}
$rows= array();
$rows = getFiles (&#39;E:/logs&#39;);
print_r($rows);
Nach dem Login kopieren

Das Obige ist ein Beispiel für die Implementierung der Rekursion in PHP, die vom Herausgeber eingeführt wurde. Detaillierte Erklärung, hoffe es hilft allen! !

Empfohlene Artikel:

Vereinfachter rekursiver PHP-Algorithmus

Die rekursive Funktion ist Eine selbstaufrufende Funktion ruft sich selbst direkt oder direkt innerhalb des Funktionskörpers auf, aber die Bedingungen für den Selbstaufruf müssen festgelegt werden. Wenn die Bedingungen erfüllt sind, wird die Funktion selbst aufgerufen...

PHP erfordert keine Rekursion. Implementierung des Infinitus-Klassifizierungsbaums

Wie implementiert man den Infinitus-Klassifizierungsbaum in PHP ohne Rekursion? In diesem Artikel wird hauptsächlich PHP vorgestellt, um durch Vorbestellungsbaumdurchquerung eine unendliche Klassifizierung ohne Rekursion zu erreichen ...

Das obige ist der detaillierte Inhalt vonDetaillierte Erläuterung des Funktionsmechanismus und Beispiele der Rekursion in PHP. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Repo: Wie man Teamkollegen wiederbelebt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

CakePHP-Projektkonfiguration CakePHP-Projektkonfiguration Sep 10, 2024 pm 05:25 PM

In diesem Kapitel werden wir die Umgebungsvariablen, die allgemeine Konfiguration, die Datenbankkonfiguration und die E-Mail-Konfiguration in CakePHP verstehen.

PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian PHP 8.4 Installations- und Upgrade-Anleitung für Ubuntu und Debian Dec 24, 2024 pm 04:42 PM

PHP 8.4 bringt mehrere neue Funktionen, Sicherheitsverbesserungen und Leistungsverbesserungen mit einer beträchtlichen Menge an veralteten und entfernten Funktionen. In dieser Anleitung wird erklärt, wie Sie PHP 8.4 installieren oder auf PHP 8.4 auf Ubuntu, Debian oder deren Derivaten aktualisieren. Obwohl es möglich ist, PHP aus dem Quellcode zu kompilieren, ist die Installation aus einem APT-Repository wie unten erläutert oft schneller und sicherer, da diese Repositorys in Zukunft die neuesten Fehlerbehebungen und Sicherheitsupdates bereitstellen.

CakePHP Datum und Uhrzeit CakePHP Datum und Uhrzeit Sep 10, 2024 pm 05:27 PM

Um in cakephp4 mit Datum und Uhrzeit zu arbeiten, verwenden wir die verfügbare FrozenTime-Klasse.

CakePHP-Datei hochladen CakePHP-Datei hochladen Sep 10, 2024 pm 05:27 PM

Um am Datei-Upload zu arbeiten, verwenden wir den Formular-Helfer. Hier ist ein Beispiel für den Datei-Upload.

CakePHP-Routing CakePHP-Routing Sep 10, 2024 pm 05:25 PM

In diesem Kapitel lernen wir die folgenden Themen im Zusammenhang mit dem Routing kennen.

Besprechen Sie CakePHP Besprechen Sie CakePHP Sep 10, 2024 pm 05:28 PM

CakePHP ist ein Open-Source-Framework für PHP. Es soll die Entwicklung, Bereitstellung und Wartung von Anwendungen erheblich vereinfachen. CakePHP basiert auf einer MVC-ähnlichen Architektur, die sowohl leistungsstark als auch leicht zu verstehen ist. Modelle, Ansichten und Controller gu

CakePHP erstellt Validatoren CakePHP erstellt Validatoren Sep 10, 2024 pm 05:26 PM

Der Validator kann durch Hinzufügen der folgenden zwei Zeilen im Controller erstellt werden.

So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein So richten Sie Visual Studio-Code (VS-Code) für die PHP-Entwicklung ein Dec 20, 2024 am 11:31 AM

Visual Studio Code, auch bekannt als VS Code, ist ein kostenloser Quellcode-Editor – oder eine integrierte Entwicklungsumgebung (IDE) –, die für alle gängigen Betriebssysteme verfügbar ist. Mit einer großen Sammlung von Erweiterungen für viele Programmiersprachen kann VS Code c

See all articles