阅读量:0
在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函数,我们可以方便地进行递归搜索文件或目录,并找到符合特定条件的文件或目录。