在 Linux 中,copendir
函数本身并不提供递归遍历目录的功能。copendir
用于打开一个目录流,以便后续使用 readdir
等函数读取目录内容。要实现递归遍历目录,通常需要结合使用 opendir
、readdir
和 closedir
函数,并在遇到子目录时递归调用遍历函数。
以下是一个使用 C 语言实现的递归遍历目录的示例代码:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <dirent.h>
#include <sys/stat.h>
// 递归遍历目录的函数
void recursive_directory_traversal(const char *path) {
DIR *dir;
struct dirent *entry;
struct stat path_stat;
// 打开当前目录
dir = opendir(path);
if (dir == NULL) {
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 (stat(full_path, &path_stat) == -1) {
perror("stat");
continue;
}
// 如果是目录,则递归遍历
if (S_ISDIR(path_stat.st_mode)) {
printf("Directory: %s\n", full_path);
recursive_directory_traversal(full_path);
} else {
// 如果是文件,则打印文件名
printf("File: %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;
}
// 开始递归遍历
printf("Starting recursive directory traversal from: %s\n", argv[1]);
recursive_directory_traversal(argv[1]);
return EXIT_SUCCESS;
}
打开目录:
opendir
函数打开指定路径的目录。如果打开失败,输出错误信息并返回。读取目录项:
readdir
函数逐个读取目录中的条目。"."
和 ".."
这两个特殊条目,避免递归到上级目录。获取文件/目录信息:
stat
函数获取每个条目的详细信息,包括是否为目录。递归遍历子目录:
S_ISDIR
判断),则打印目录名并递归调用 recursive_directory_traversal
函数。关闭目录流:
closedir
函数关闭目录流,释放资源。主函数:
将上述代码保存为 recursive_traverse.c
,然后使用以下命令编译和运行:
gcc -o recursive_traverse recursive_traverse.c
./recursive_traverse /path/to/start/directory
lstat
和检查 S_ISLNK
来处理符号链接,避免重复遍历。snprintf
构建路径时,确保缓冲区足够大以避免溢出。PATH_MAX
通常定义了路径的最大长度,但在某些系统上可能需要使用其他方法处理长路径。通过上述方法,可以实现一个基本的递归目录遍历功能。根据具体需求,还可以扩展功能,例如处理隐藏文件、过滤特定类型的文件、统计文件数量等。