温馨提示×

Linux readdir遍历目录顺序

小樊
38
2025-09-03 14:11:24
栏目: 智能运维

在Linux中,使用readdir()函数遍历目录时,返回的文件和子目录的顺序是不确定的。这是因为底层文件系统可能会根据不同的因素(如文件名、索引节点等)对目录内容进行排序。

如果你需要对目录中的文件进行排序,可以在调用readdir()之后,将结果存储在一个数组或其他数据结构中,并使用适当的排序算法(如qsort())对其进行排序。例如,你可以根据文件名对目录内容进行排序:

#include <dirent.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int compare(const void *a, const void *b) {
    return strcmp(*(const char **)a, *(const char **)b);
}

int main() {
    DIR *dir;
    struct dirent *entry;
    char *files[100];

    dir = opendir(".");
    if (dir == NULL) {
        perror("opendir");
        return 1;
    }

    int i = 0;
    while ((entry = readdir(dir)) != NULL) {
        files[i++] = strdup(entry->d_name);
    }
    closedir(dir);

    qsort(files, i, sizeof(char *), compare);

    for (int j = 0; j < i; j++) {
        printf("%s\n", files[j]);
        free(files[j]);
    }

    return 0;
}

这个示例程序会打开当前目录(.),读取其中的文件和子目录,将它们存储在一个字符串数组中,然后使用qsort()函数对数组进行排序。最后,它会打印排序后的文件名并释放分配的内存。

0