readdir 函数本身不提供自定义排序功能,它返回的目录条目顺序取决于底层文件系统。 要实现自定义排序,需要在读取目录后,使用程序代码进行排序。

以下示例演示如何结合 readdir 和 qsort 对目录中的文件名进行排序:
#include #include #include #include //比较函数,用于qsortint compare(const void *a, const void *b) { return strcmp(*(const char **)a, *(const char **)b);}int main() { DIR *dir; struct dirent *entry; char **filenames; // 使用char**动态分配内存,更灵活 int count = 0; int i; dir = opendir("."); if (dir == NULL) { perror("opendir"); return 1; } // 首先获取目录条目数量,以便动态分配内存 while ((entry = readdir(dir)) != NULL) { count++; } rewinddir(dir); // 重置目录流指针 filenames = (char **)malloc(count * sizeof(char *)); if (filenames == NULL) { perror("malloc"); closedir(dir); return 1; } count = 0; // 重置计数器 while ((entry = readdir(dir)) != NULL) { if (entry->d_type == DT_REG) { // 只处理普通文件 filenames[count] = strdup(entry->d_name); if (filenames[count] == NULL) { perror("strdup"); // 处理内存分配失败 for (i = 0; i < count; i++) { free(filenames[i]); } free(filenames); closedir(dir); return 1; } count++; } } closedir(dir); qsort(filenames, count, sizeof(char *), compare); for (i = 0; i < count; i++) { printf("%sn", filenames[i]); free(filenames[i]); // 释放strdup分配的内存 } free(filenames); // 释放filenames数组的内存 return 0;}
此代码首先使用 readdir 读取目录中的所有条目,然后使用 qsort 进行排序,最后打印排序后的文件名并释放所有动态分配的内存,避免内存泄漏。 改进之处在于动态分配内存,避免了固定大小数组的限制,并添加了错误处理和内存释放。 记住编译时需要链接 -lm (用于 malloc 和 free)。
以上就是debian readdir是否支持自定义排序的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1386793.html
微信扫一扫
支付宝扫一扫