linux

如何用copendir实现Linux目录的递归遍历

小樊
56
2025-03-31 08:33:13
栏目: 智能运维

在Linux中,opendirreaddirclosedir 是用于遍历目录的标准C库函数。然而,这些函数本身并不支持递归遍历目录。要实现递归遍历,你需要编写一个递归函数来处理子目录。下面是一个示例代码,演示如何使用这些函数递归遍历目录:

#include <stdio.h>
#include <stdlib.h>
#include <dirent.h>
#include <string.h>
#include <sys/stat.h>

void list_directory_contents(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);
            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 <directory>\n", argv[0]);
        return EXIT_FAILURE;
    }

    list_directory_contents(argv[1]);

    return EXIT_SUCCESS;
}

代码说明:

  1. 打开目录:使用 opendir 函数打开指定路径的目录。

  2. 读取目录条目:使用 readdir 函数读取目录中的每个条目。

  3. 跳过特殊条目:忽略当前目录(.)和父目录(..)。

  4. 构建完整路径:使用 snprintf 构建每个条目的完整路径。

  5. 获取文件/目录信息:使用 stat 函数获取文件或目录的信息,以便判断它是文件还是目录。

  6. 递归处理子目录:如果条目是一个目录(通过 S_ISDIR 判断),则递归调用 list_directory_contents 函数。

  7. 关闭目录:使用 closedir 函数关闭目录。

编译和运行:

将上述代码保存为 recursive_directory_traversal.c,然后使用以下命令编译和运行:

gcc -o recursive_directory_traversal recursive_directory_traversal.c
./recursive_directory_traversal /path/to/directory

替换 /path/to/directory 为你想要遍历的目录路径。这个程序将递归地列出指定目录及其所有子目录中的文件和目录。

0
看了该问题的人还看了