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/');
這個遞歸是網上搜的,看了他的註釋越看越懵
下面的遞歸與他的作用一樣
$path = '11/22/33/44';
// 归前的语句顺序执行,递归后的语句倒序执行
function mkdirs($path)
{
if(is_dir($path)){
return;
}
mkdirs( dirname($path) );
return $path;
// mkdir($path);
}
mkdirs($path);
幫忙分析下了個函數有什麼差別?
第一個遞歸的註解是否正確?
大家讲道理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"
... ....