copendir 函数本身并不支持递归查找目录,它主要用于打开一个目录流。要实现目录的递归查找,你需要结合 readdir 函数来遍历目录,并在遇到子目录时递归调用查找函数。以下是一个使用 C 语言实现的示例:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dirent.h>
#include <sys/stat.h>
void list_directory_recursive(const char *path) {
DIR *dir;
struct dirent *entry;
struct stat statbuf;
if (!(dir = opendir(path))) {
perror("opendir");
return;
}
while ((entry = readdir(dir)) != NULL) {
if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0)
continue;
char full_path[PATH_MAX];
snprintf(full_path, sizeof(full_path), "%s/%s", path, entry->d_name);
if (lstat(full_path, &statbuf) == -1) {
perror("lstat");
continue;
}
if (S_ISDIR(statbuf.st_mode)) {
list_directory_recursive(full_path);
} else {
printf("%s\n", full_path);
}
}
closedir(dir);
}
int main(int argc, char *argv[]) {
if (argc != 2) {
fprintf(stderr, "Usage: %s <directory>\n", argv[0]);
return EXIT_FAILURE;
}
list_directory_recursive(argv[1]);
return EXIT_SUCCESS;
}
这个程序接受一个目录路径作为命令行参数,并递归地列出该目录下的所有文件和子目录。请注意,这个示例没有处理符号链接,如果目录中包含符号链接,可能会导致无限递归。要处理符号链接,你需要在 lstat 之后检查 S_ISLNK 标志,并相应地处理符号链接。