本文介绍如何利用Linux系统下的标准C库函数opendir、readdir和closedir实现目录的递归遍历。 虽然这些函数本身并不支持递归,但我们可以通过编写递归函数来完成此功能。
以下代码示例演示了如何使用这些函数递归遍历给定目录:
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <string.h> #include <sys/stat.h> void traverseDirectory(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 fullPath[PATH_MAX]; snprintf(fullPath, sizeof(fullPath), "%s/%s", path, entry->d_name); // 获取文件/目录信息 if (stat(fullPath, &path_stat) == -1) { perror("stat"); continue; } // 递归处理子目录 if (S_ISDIR(path_stat.st_mode)) { printf("目录: %sn", fullPath); traverseDirectory(fullPath); } else { // 打印文件 printf("文件: %sn", fullPath); } } // 关闭目录 closedir(dir); } int main(int argc, char *argv[]) { if (argc != 2) { fprintf(stderr, "用法: %s <目录路径>n", argv[0]); return EXIT_FAILURE; } traverseDirectory(argv[1]); return EXIT_SUCCESS; }
代码说明:
- 打开目录: opendir()函数打开指定的目录。
- 读取目录条目: readdir()函数逐个读取目录中的条目。
- 跳过特殊条目: 代码跳过表示当前目录(“.”)和父目录(“..”)的条目。
- 构建完整路径: snprintf()函数构建每个条目的完整路径。
- 获取文件/目录信息: stat()函数获取文件或目录的属性信息,用于判断是文件还是目录。
- 递归处理: 如果条目是目录(S_ISDIR()),则递归调用traverseDirectory()函数。
- 关闭目录: closedir()函数关闭打开的目录。
编译和运行:
将代码保存为例如recursive_traversal.c,然后使用以下命令编译和运行:
gcc -o recursive_traversal recursive_traversal.c ./recursive_traversal /path/to/your/directory
将/path/to/your/directory替换成你想要遍历的目录路径。 程序会递归地列出该目录及其所有子目录下的文件和目录。
这个改进后的版本使用了更清晰的变量名和注释,并对代码结构进行了微调,使其更易于理解和维护。