在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()
函數對數組進行排序。最后,它會打印排序后的文件名并釋放分配的內存。