linux scandir 排序,linux scandir 的使用

(1) 头文件

#include

(2) 函数定义

int scandir(const char *dir,struct dirent **namelist,int (*filter)(const void *b),

int ( * compare )( const struct dirent **, const struct dirent ** ) );

int alphasort(const void *a, const void *b);

int versionsort(const void *a, const void *b);

(3) 使用说明

函数scandir扫描dir目录下以及dir子目录下满足filter过滤模式的文件,返回的结果是compare函数经过排序的,并保存在 namelist中。注意namelist是通过malloc动态分配内存的,所以在使用时要注意释放内存。alphasort和versionsort 是使用到的两种排序的函数。

当函数成功执行时返回找到匹配模式文件的个数,如果失败将返回-1。

(4) 使用示例

/*     scandir函数 */ #include #include int customFilter(const struct dirent *pDir) {     if (strncmp("test", pDir->d_name, 4) == 0             && pDir->d_type & 0x04             && strcmp(pDir->d_name, ".")             && strcmp(pDir->d_name, ".."))     {         return 1;     }     return 0; } int main() {     struct dirent **namelist;     int n;     int i;     n = scandir(".", &namelist, customFilter, alphasort);     if (n < 0)     {         perror("scandir");     }     else     {         for (i = 0; i < n; i++)         {             printf("%s\n", namelist[i]->d_name);             free(namelist[i]);         }         free(namelist);     } }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值