Heim > Backend-Entwicklung > PHP-Tutorial > Detaillierte Erklärung der rekursiven PHP-Funktion

Detaillierte Erklärung der rekursiven PHP-Funktion

小云云
Freigeben: 2023-03-20 12:42:02
Original
3719 Leute haben es durchsucht

In Bezug auf die Verwendung rekursiver PHP-Funktionen geben wir Ihnen einige Beispiele für rekursive PHP-Funktionen. In der PHP-Programmierung ist es sehr üblich, rekursive Funktionen zu verwenden, um die Codeeffizienz zu verbessern Beispiele.

1. Was ist eine rekursive Funktion?

Eine Funktion, die sich selbst innerhalb ihres Funktionskörpers aufruft, wird als rekursiver Aufruf bezeichnet. Diese Art von Funktion wird als rekursive Funktion bezeichnet.

Was ist der Unterschied zwischen rekursiven PHP-Funktionen und nicht-rekursiven Funktionen?

Beispiel 1: Verwendung statischer Variablen

Codebeispiel:

function test(){
 static $dig=0;
 if($dig++<10){
  echo $dig;
  test();
 }
}
test();//12345678910
Nach dem Login kopieren

Beispiel 2: Verwendung rekursiver Funktionen und Schleifen zur Implementierung der String-Umkehranordnung

Code Beispiel:

function unreverse($str){
 for($i=1;$i<=strlen($str);$i++){
  echo substr($str,-$i,1);
 }
}
unreverse("abcdefg");//gfedcbc
function reverse($str){
 if(strlen($str)>0){
  reverse(substr($str,1));
  echo substr($str,0,1);
  return;
 }
}
reverse("abcdefg");//gfedcbc
Nach dem Login kopieren

2. Beispiel für die Verwendung einer rekursiven PHP-Funktion

Beispiel für die Verwendung einer rekursiven PHP-Funktion (rekursive PHP-Funktion), einschließlich rekursiver Erlangung der Rollen-ID-Zeichenfolge, rekursiver Erlangung des kaskadierten Rolleninformationsarrays, Rufen Sie Informationen zur untergeordneten Rolle über die ID der übergeordneten Rolle ab.

Beispiel:

Codebeispiel:

//递归获得角色ID字符串
function explodeRole($roleObj, &$resultStr){
 if(0 < count($roleObj->childRoleObjArr)){
 foreach($roleObj->childRoleObjArr as $childRoleObj){
  if('' == $resultStr){
  $resultStr .= "{$childRoleObj->id}";
  }else{
  $resultStr .= ", {$childRoleObj->id}";
  }
  explodeRole($childRoleObj, $resultStr);
 }
 }
}
//递归获取级联角色信息数组
function makeRoleRelation(&$roleObjArr){
 foreach($roleObjArr as $item){
 $item->childRoleObjArr = getRoleObjArrByParentId($item->id);
 if(0 < count($item->childRoleObjArr)){
  makeRoleRelation($item->childRoleObjArr);
 }
 }
}
//通过父角色的id获取子角色信息 
function getRoleObjArrByParentId($parentid){
 $operCOGPSTRTSysRole = new COGPSTRTSysRole();
 $operCOGPSTRTSysRole->setColumn($operCOGPSTRTSysRole->getAllColumn());
 $operCOGPSTRTSysRole->setWhere("parentroleid={$parentid}");
 $roleObjArr = $operCOGPSTRTSysRole->convResult2ObjArr($operCOGPSTRTSysRole->selectTable());
 return isset($roleObjArr)?$roleObjArr:array();
}
Nach dem Login kopieren

Verwendung rekursiver PHP-Funktionen

Beispiel 1: Verwenden Sie statische Variablen, um die Rekursion zu implementieren.

Codebeispiel:

function test(){
 static $dig=0;
 if($dig++<10){
 echo $dig;
 test();
 }
}
test();//12345678910
Nach dem Login kopieren

Beispiel 2: Verwenden Sie rekursive Funktionen und Schleifen, um die Zeichenfolgenanordnung umzukehren.

Codebeispiel:

function unreverse($str){
for($i=1;$i<=strlen($str);$i++){
echo substr($str,-$i,1);
}
}
unreverse("abcdefg");
//gfedcbc
function reverse($str){
if(strlen($str)>0){
reverse(substr($str,1));
echo substr($str,0,1); return;
}
}
reverse("abcdefg");//gfedcbc
Nach dem Login kopieren

Rekursive PHP-Funktionen können manchmal durch Schleifen ersetzt werden. Es wird empfohlen, sie zu verwenden, wenn Schleifen nicht verwendet werden können, da sie für uns einfacher und weniger verständlich sind fehleranfällig bei Schleifen. Rekursive PHP-Funktionen: Rekursive Funktionen rufen sich selbst auf. Diese Funktionen eignen sich besonders zum Durchsuchen dynamischer Datenstrukturen wie Bäume und Listen. Nur wenige Webanwendungen erfordern die Verwendung komplexer Datenstrukturen.

Beispiel:

Codebeispiel:

reverse_r(substr($str,1)); echo substr($str,0,1); return; } ?>
Nach dem Login kopieren

Diese Programmauflistung implementiert zwei Funktionen, die beide den Inhalt einer Zeichenfolge in umgekehrter Reihenfolge drucken können. reversr_r ist implementiert durch Rekursion, während die Funktion reverse_i() durch Schleifen implementiert wird.

Verwandte Empfehlungen:

php löscht das gesamte Verzeichnis durch rekursive Funktionen

Problemlösung für rekursive Funktionen in JavaScript

Erklärung zum Aufruf rekursiver PHP-Funktionen

Das obige ist der detaillierte Inhalt vonDetaillierte Erklärung der rekursiven PHP-Funktion. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage