Heim > Fragen und Antworten > Hauptteil
function mkDirs1($path){
if(is_dir($path)){//已经是目录了就不用创建
return true;
}
if(is_dir(dirname($path))){//父目录已经存在,直接创建
return mkdir($path);
}
mkDirs1(dirname($path));//从子目录往上创建
return mkdir($path);//因为有父目录,所以可以创建路径
}
//mkDirs1('1/2/3/');
Diese Rekursion wurde im Internet gesucht, je mehr ich seine Kommentare las, desto verwirrter wurde ich
Die folgende Rekursion hat die gleiche Funktion wie sie
$path = '11/22/33/44';
// 归前的语句顺序执行,递归后的语句倒序执行
function mkdirs($path)
{
if(is_dir($path)){
return;
}
mkdirs( dirname($path) );
return $path;
// mkdir($path);
}
mkdirs($path);
Helfen Sie, den Unterschied zwischen den folgenden Funktionen zu analysieren?
Ist der erste rekursive Kommentar korrekt?
大家讲道理2017-06-30 09:58:06
例子的递归是正确的,这个可以用一个函数替代:mkdir($sPath,0777,true);第三个参数为递归创建
递归创建过程
//递归寻找文件夹存在的父级目录,假设存在的父级目录为11
//进行递归向上级寻找
11/22/33/44
11/22/33
11/22
11
11/22 //在最上级目录开始逐级创建子目录
11/22/33
11/22/33/44
这就是递归的执行过程
PHP中文网2017-06-30 09:58:06
第二个写错了,你把mkdir注释了,再怎么递归也不能创建目录,而且mkdir的位置放错了,应该这样:
function mkdirs($path)
{
if(is_dir($path)){
return;
}
mkdirs( dirname($path) );
mkdir($path);
return $path;
}
关于解释,你把参数代进去,一步一步去分析。
试着分析几个参数试一下:
"./a"
"./a/b"
"./a/b/c"
"./a/b/c/d"
.......