在C++中,可以使用glob函数来进行递归搜索文件或目录。glob函数可以匹配指定模式的文件或目录,并返回一个包含匹配结果的字符串数组。
以下是一个简单的例子,演示如何在C++中使用glob函数进行递归搜索:
#include <iostream>
#include <glob.h>
void searchFiles(const std::string& pattern) {
glob_t glob_result;
glob(pattern.c_str(), GLOB_TILDE, NULL, &glob_result);
for(size_t i = 0; i < glob_result.gl_pathc; ++i){
std::cout << glob_result.gl_pathv[i] << std::endl;
}
for(size_t i = 0; i < glob_result.gl_pathc; ++i){
if(glob_result.gl_pathv[i][strlen(glob_result.gl_pathv[i]) - 1] == '/'){
searchFiles(std::string(glob_result.gl_pathv[i]) + "*");
}
}
globfree(&glob_result);
}
int main() {
searchFiles("path/to/search/*");
return 0;
}
在上面的代码中,我们定义了一个名为searchFiles的函数,它接受一个文件或目录的匹配模式作为参数。在函数内部,我们使用glob函数来搜索匹配指定模式的文件或目录,并将结果打印出来。然后我们递归搜索每个子目录,直到找到所有匹配的文件或目录为止。
通过使用glob函数,我们可以方便地进行递归搜索文件或目录,并找到符合特定条件的文件或目录。