
本文介绍如何利用 copendir 函数和 readdir 函数递归遍历目录结构。 以下代码示例展示了这一过程:
#include#include #include #include #include #include // Include for PATH_MAX void traverseDirectory(const char *path) { DIR *dir = opendir(path); if (dir == NULL) { perror("opendir"); return; } struct dirent *entry; while ((entry = readdir(dir)) != NULL) { if (strcmp(entry->d_name, ".") == 0 || strcmp(entry->d_name, "..") == 0) { continue; // Skip "." and ".." entries } char fullPath[PATH_MAX]; snprintf(fullPath, PATH_MAX, "%s/%s", path, entry->d_name); struct stat statbuf; if (stat(fullPath, &statbuf) == -1) { perror("stat"); continue; } if (S_ISDIR(statbuf.st_mode)) { printf("Directory: %s\n", fullPath); traverseDirectory(fullPath); // Recursive call for subdirectories } else { printf("File: %s\n", fullPath); } } closedir(dir); } int main(int argc, char *argv[]) { if (argc != 2) { fprintf(stderr, "Usage: %s \n", argv[0]); return EXIT_FAILURE; } traverseDirectory(argv[1]); return EXIT_SUCCESS; }
代码功能说明:
-
打开目录:
opendir(path)函数打开指定的目录。 -
读取目录项:
readdir(dir)函数逐个读取目录中的文件和子目录信息。 - 跳过特殊项: 代码跳过 "." (当前目录) 和 ".." (父目录) 项。
-
构建完整路径:
snprintf函数构建每个文件或子目录的完整路径。 -
获取文件状态:
stat(fullPath, &statbuf)获取文件状态信息,用于判断是文件还是目录。 -
递归遍历: 如果
statbuf指示是目录 (S_ISDIR),则递归调用traverseDirectory函数处理子目录。 -
关闭目录:
closedir(dir)关闭打开的目录流,释放资源。
使用方法:
- 将代码保存为
.c文件 (例如listdir.c)。 - 使用 GCC 编译:
gcc -o listdir listdir.c - 运行程序,并指定要遍历的目录路径作为参数:
./listdir /path/to/your/directory
此程序将打印出指定目录及其所有子目录中所有文件和子目录的完整路径。 请确保您具有访问指定目录的权限。 添加了 limits.h 头文件和 PATH_MAX 常量,以确保路径长度的正确处理,避免缓冲区溢出。










