linux程序设计目录扫描实验问题

源代码:

#include<unistd.h>
#include<stdio.h>
#include<dirent.h>
#include<string.h>
#include<sys/stat.h>
#include<stdlib.h>

void printfdir(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)
    {
      lstat(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);
	  printfdir(entry->d_name,depth+4);
	}
      else printf("%*s%s\n",depth," ",entry->d_name);
    }
      chdir(".."); 
      closedir(dp);
}


int main()
{
  printf("Directory scan of /home:\n");
  printfdir("/home/xgl/Code",0);
  printf("done.\n");
  exit(0);
}

问题:为什么while循环后要切换到上层目录?递归完成后不是会自动回到上层么。将31行注释后发现虽然能输出上层目录包含的目录或文件,但均被识别为目录,且包含的目录不会进行递归。

原因:递归后程序确实跳回上层,所以能输出上层目录包括的目录和文件,但是由于lstat函数传入的只是文件或目录的相对路径,如果不将当前程序扫描目录带回上一级的话,它只会在下层扫描该文件名,但下层是没有该文件或目录的。将传给lstat函数的地址改为绝对路径就没问题了(一点不方便)

代码如下:

#include<unistd.h>
#include<stdio.h>
#include<dirent.h>
#include<string.h>
#include<sys/stat.h>
#include<stdlib.h>

void printfdir(char *dir,int depth)
{
  DIR *dp;
  struct dirent *entry;
  struct stat statbuf;
  char pwd[256];
  if((dp=opendir(dir))==NULL)
    {
      fprintf(stderr,"cannot open directory: %s\n",dir);
      return;
    }
  chdir(dir);
  while ((entry=readdir(dp))!=NULL)
    {
      sprintf(pwd,"%s/%s",dir,entry->d_name);
      lstat(pwd,&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);
	  printfdir(pwd,depth+4);
	}
      else printf("%*s%s\n",depth," ",entry->d_name);
    }
  // chdir(".."); 
      closedir(dp);
}


int main()
{
  printf("Directory scan of /home:\n");
  printfdir("/home/xgl/Code",0);
  printf("done.\n");
  exit(0);
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值