您的位置:首页 >readdir如何遍历子目录
发布于2026-05-02 阅读(0)
扫一扫,手机访问
在C语言中处理文件系统时,readdir函数是读取目录内容的核心工具。但如果你想深入目录的“腹地”,遍历其下的所有子目录,就需要引入递归逻辑。简单来说,就是让程序在遇到一个目录时,能再次调用自己来处理这个新目录。

下面这个示例清晰地展示了如何结合opendir、readdir和stat函数来实现这一目标:
#include
#include
#include
#include
#include
void list_directory_contents(const char *path) {
DIR *dir;
struct dirent *entry;
struct stat path_stat;
char full_path[1024];
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;
}
// 构建完整的文件/目录路径
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);
// 关键在此:递归调用自身,进入子目录
list_directory_contents(full_path);
} else {
printf("File: %s\n", full_path);
}
}
closedir(dir);
}
int main(int argc, char *argv[]) {
if (argc != 2) {
fprintf(stderr, "Usage: %s \n", argv[0]);
return EXIT_FAILURE;
}
list_directory_contents(argv[1]);
return EXIT_SUCCESS;
}
这个程序的工作流程很直观:你通过命令行传入一个目录路径,它便会递归地列出该目录下所有的文件和子目录。不过需要注意的是,这只是一个基础模型。在实际开发中,像符号链接处理、路径长度缓冲区溢出防范、更精细的错误处理等情况,都需要你根据具体的应用场景来补充和完善。毕竟,一个健壮的文件遍历器,细节决定成败。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9