一个搜索路径的例子程序 注释

#include "stdio.h"
#include "stdio.h"
#include "dirent.h"
#include "string.h"
#include "sys/stat.h"

void show_dir(char *dir,int depth)
{
       DIR *dp;
       struct dirent *entry;
       struct stat statbuf;

       if ((dp = opendir(dir)) == NULL) {
               fprintf(stderr,"cannot open directory:%s/n",dir);
               return;
       }

       chdir(dir); //进去当前操作目录,当有子目录时递归调用使用的是相对地址,才可以不错
       while((entry = readdir(dp)) != NULL) {
               stat(entry->d_name,&statbuf);
               if (S_ISDIR(statbuf.st_mode)) {
                       if (strcmp(".",entry->d_name) == 0 ||
                           strcmp("..",entry->d_name) == 0)
                           continue;
                       printf("%*s%s//n",depth," ",entry->d_name);
                       show_dir(entry->d_name,depth+2);
               }
               else printf("%*s%s/n",depth," ",entry->d_name);
       }

       chdir("..");//返回上级目录
       close(dp);
}

int main(int argc,char *argv[])
{
       if (argc != 2) {
               printf("usage:dir <pathname>");
               return 0;
       }

       show_dir(argv[1],0);

       exit(0);
}

例子基本简单就是chdir有点问题show_dir使用的相对地址

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值