LinuxC 遍历目录结构函数图解.

代码实现

图解

void doPath(PrinFunc func)
{
while(a

}

“`
char * fullPath;
void doPath(printfFunc func)
{
DIR *dp;
struct dirent *dirp;
struct stat statbuf;
char *ptr;
int ret;
if(lstat(fullPath, &statbuf)< 0) //当lstat函数是否事,打印出错信息.
return (func(fullpath, &statbuf,FTW_NS));
if(S_ISDIR(statbuf.st_mode) ==0) //如果是普通文件.则直接进行计数.
return ((func(fullpath,&statbuf, FTW_D))!=0);
if(func(fullpaht,&statbuf,FTW_D))!=0) return (ret);

 ptr = fullPath + strlen(fullPath); 将ptr指向最后,如 fullPath = "aaaa"
 那么ptr指向 aaaa[这个位置],之后ptr在这个位置上添加一个 [/]那么fullPath就是. 
 "aaaa/", 那么ptr 指向这个后面的一个,并讲这个值设置为0.

 *ptr="/"
 *ptr="0"; 
 /*---------------------------------------------------*/ 
 下面进入递归调用阶段. 
 if(dp= opendir(fullPath) ==NULL)  return (func(fullpath, &statbuf, FTW_DNR));
//以为strcpy(不会改变ptr的的指向.拷贝完成之后.dirp指向的还是"aaaa/"和面的字符.
//所以下次会到while(的时候, 就可以从一个文件切换到.第二个文件下.
 while((dirp= readdir(dp)!=NULL)
 {
    if(strcmp(dirp->d_name, ".") == 0 || strcmp(dirp->d_name,"..")) continue; 
    strcpy(ptr,dirp->d_name); 
    if(dopath(func)!=0) break;
}  

猜你喜欢

转载自blog.csdn.net/shaohuazuo/article/details/47863061