在debian系統中,readdir函數用于讀取目錄內容,但其返回的順序并非預先定義的。 要對目錄中的文件進行排序,需要先讀取所有文件,再利用qsort函數進行排序。
以下代碼演示了如何在Debian系統中使用readdir和qsort對目錄文件進行排序:
#include <stdio.h> #include <stdlib.h> #include <dirent.h> #include <string.h> // 自定義比較函數,用于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; // 打開當前目錄 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避免內存泄漏 if (filenames[count] == NULL) { perror("strdup"); closedir(dir); return 1; // 返回錯誤碼 } count++; } } // 關閉目錄 closedir(dir); // 使用qsort排序文件名 qsort(filenames, count, sizeof(char *), compare); // 打印排序后的文件名 for (int i = 0; i < count; i++) { printf("%sn", filenames[i]); free(filenames[i]); // 釋放內存 } free(filenames); // 釋放內存 return 0; }
這段代碼改進之處在于:使用了strdup復制文件名,避免了直接使用strcpy可能導致的內存泄漏問題;并添加了更全面的錯誤處理,在realloc和strdup失敗時進行處理,釋放已分配的內存,并返回錯誤碼。 最后,記得釋放所有動態分配的內存,避免內存泄漏。 這個版本更健壯,更適合實際應用。 請注意,實際應用中可能需要更復雜的比較函數來處理不同類型的文件排序需求。
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END