C/C++ 递归与结束递归
作者:互联网
今天碰到了一个问题,我打算递归遍历整个 Windows 目录,找 后缀名为 .pf 的文件,如果找到了一个符合要求的文件就返回。
下面是我最初的代码:
void findAllFile_cs(const char * path,const char * format,string &pfPath)
{
// 路径末尾追加 '\*.*'
char newpath[200];
strcpy(newpath, path);
strcat(newpath, "\\*.*");
// 找到目录下的第一个文件
_finddata_t findData;
/* 文件信息结构体
struct _finddata_t{
unsigned attrib; // 文件属性
time_t time_create; // 创建时的时间戳
time_t time_access; // 最后一次被访问时的时间戳
time_t time_write; // 最后一次被修改时的时间戳
_fsize_t size; // 文件字节大小
char name[_MAX_FNAME]; // 文件名
};
*/
long handle = _findfirst(newpath, &findData);
if (handle == -1){return;}
// 遍历文件和文件夹
while (_findnext(handle, &findData) == 0){
// 文件夹
if(findData.attrib & _A_SUBDIR){
// 文件夹名不能有敏感字符 '.'、'..'
if (strcmp(findData.name, ".") == 0 || strcmp(findData.name, "..") == 0){continue;}
// 进入这个文件夹继续遍历
strcpy(newpath, path);
strcat(newpath, "\\");
strcat(newpath, findData.name);
findAllFile_cs(newpath,format,pfPath);
}
// 文件
else{
// 判断是不是指定后缀的文件
if(strstr(findData.name,format)){
// 输出(用来测试)
//cout << "findData.size = " << findData.size << endl;
//cout << "findData.name = " << findData.name << endl;
//cout << "path = " << path << endl;
// 取文件所在路径
pfPath = path;
return;
}
}
}
// 关闭搜索句柄
_findclose(handle);
}
执行过程:
然后是修改过后的代码:
int findAllFile_cs(const char * path,const char * format,string &pfPath)
{
// 路径末尾追加 '\*.*'
char newpath[200];
strcpy(newpath, path);
strcat(newpath, "\\*.*");
// 找到目录下的第一个文件
_finddata_t findData;
/* 文件信息结构体
struct _finddata_t{
unsigned attrib; // 文件属性
time_t time_create; // 创建时的时间戳
time_t time_access; // 最后一次被访问时的时间戳
time_t time_write; // 最后一次被修改时的时间戳
_fsize_t size; // 文件字节大小
char name[_MAX_FNAME]; // 文件名
};
*/
long handle = _findfirst(newpath, &findData);
if (handle == -1){return 1;}
// 遍历文件和文件夹
while (_findnext(handle, &findData) == 0){
// 文件夹
if(findData.attrib & _A_SUBDIR){
// 文件夹名不能有敏感字符 '.'、'..'
if (strcmp(findData.name, ".") == 0 || strcmp(findData.name, "..") == 0){continue;}
// 进入这个文件夹继续遍历
strcpy(newpath, path);
strcat(newpath, "\\");
strcat(newpath, findData.name);
if(findAllFile_cs(newpath,format,pfPath) == 0){break;}
}
// 文件
else{
// 判断是不是指定后缀的文件
if(strstr(findData.name,format)){
// 输出(用来测试)
//cout << "findData.size = " << findData.size << endl;
//cout << "findData.name = " << findData.name << endl;
//cout << "path = " << path << endl;
// 取文件所在路径
pfPath = path;
return 0;
}
}
}
// 关闭搜索句柄
_findclose(handle);
return 1;
}
执行过程:
这个还是很实用的,因为有时候我们只需要判断 “有没有某个东西”,而全部扫描一遍是很浪费时间的。
标签:newpath,文件,结束,name,递归,C++,char,time,findData 来源: https://www.cnblogs.com/LyShark/p/15019615.html