用递归的方法输出以命令行参数的形式给定的目录下的所有子目录。
整体思路:
参考树的遍历,每打开一个目录判断当前打开的是目录还是文件,是文件则终止,是目录则继续递归打开其子目录,直到给定目录下的所有目录均被输出为止,本文用到的是dfs序。
要解决的问题:
- 如何读取linux下的命令行参数
- 如何打开并读取某个目录
- 如何判断当前打开的是目录还是文件
- 如何输出已经打开的目录或者文件
解决方案
读取linux下的命令行参数方法:
int main(int argc,char* argv[])
- argc是命令行总的参数个数 (自动生成,不需要填写)
- **argv[]**是argc个参数,其中第0个参数是程序的全名,以后的参数是命令行后面跟的用户输入的参数。
- 使用方法:
vs下使用方法:工程–>属性–>配置属性–>调试->“命令参数”
本文采用的代码均在Linux命令行中实现,只需在执行可执行文件时在其后填写参数即可:
例如:
./File ..
//File是可执行文件名,(“..”)是给的参数,表示当前目录的父目录
如何打开并读取某个目录:
文件的打开和关闭,这里用到两个函数
opendir() //打开一个目录
closedir() //关闭一个目录
//原型分别为
DIR *opendir(const char *name);//返回DIR *类型的指针,稍后就能用到
int closedir(DIR *dir);
文件的读取用到一个函数
readdir();
//函数原型如下
struct dirent *readdir(DIR *dir);
通过对以上三个函数的原型的观察,不难发现opendir() 的返回类型正是readdir()需要的参数。所以我们在程序中定义一个 D