在Debian系統(tǒng)中,readdir函數(shù)用于讀取目錄內(nèi)容,但其返回的順序并非預(yù)先定義的。 要對目錄中的文件進(jìn)行排序,需要先讀取所有文件,再利用qsort函數(shù)進(jìn)行排序。
以下代碼演示了如何在Debian系統(tǒng)中使用readdir和qsort對目錄文件進(jìn)行排序:
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <string.h> // 自定義比較函數(shù),用于qsort int compare(const void *a, const void *b) { return strcmp(*(const char **)a, *(const char **)b); } int main() { DIR *dir; struct dirent *entry; char **filenames = NULL; int count = 0; // 打開當(dāng)前目錄 dir = opendir("."); if (dir == NULL) { perror("opendir"); return 1; // 返回錯誤碼 } // 讀取目錄條目 while ((entry = readdir(dir)) != NULL) { // 忽略"."和".." if (strcmp(entry->d_name, ".") != 0 && strcmp(entry->d_name, "..") != 0) { filenames = realloc(filenames, (count + 1) * sizeof(char *)); if (filenames == NULL) { perror("realloc"); closedir(dir); return 1; // 返回錯誤碼 } filenames[count] = strdup(entry->d_name); // 使用strdup避免內(nèi)存泄漏 if (filenames[count] == NULL) { perror("strdup"); closedir(dir); return 1; // 返回錯誤碼 } count++; } } // 關(guān)閉目錄 closedir(dir); // 使用qsort排序文件名 qsort(filenames, count, sizeof(char *), compare); // 打印排序后的文件名 for (int i = 0; i < count; i++) { printf("%sn", filenames[i]); free(filenames[i]); // 釋放內(nèi)存 } free(filenames); // 釋放內(nèi)存 return 0; }
這段代碼改進(jìn)之處在于:使用了strdup復(fù)制文件名,避免了直接使用strcpy可能導(dǎo)致的內(nèi)存泄漏問題;并添加了更全面的錯誤處理,在realloc和strdup失敗時進(jìn)行處理,釋放已分配的內(nèi)存,并返回錯誤碼。 最后,記得釋放所有動態(tài)分配的內(nèi)存,避免內(nèi)存泄漏。 這個版本更健壯,更適合實際應(yīng)用。 請注意,實際應(yīng)用中可能需要更復(fù)雜的比較函數(shù)來處理不同類型的文件排序需求。