目录
使用命令行参数获取用户在DOS命令行输入的指令:
方法:代码如下:
使用命令行参数获取并打印部分或者整体环境变量的方法:
方法1:
运行结果:
方法2:使用外部链接environ:
使用命令行参数获取用户在DOS命令行输入的指令:
方法:代码如下:
上方代码解析:
argc : 命令行传入参数的总个数
argv : char* argv[ ]是一个指针数组,里面存放的元素全是指针,这些指针会指向所有的命令行参数,例如:argv[0]指向程序的全路径名(这个是固定的),argv[1]指向在DOS命令行中执行程序名后的第一个字符串,argv[2]指向第二个DOS命令行输入的第二个子字符串。
也就是说下标0位置处的argv指向的永远是指向该文件的路径名,剩下的从下标1开始的元素指针指向的是文件后面的各个指令。
编译后运行该结果:
如上,在Dos命令行中只输入了该程序的路径名,所以argc的个数为1,那么argv[0]指向的就是程序的全路径名。
当我们在DOS命令行中不仅运行该程序,还在其后面+选项:
解析:实际上我们在命令行上输入的命令,是一个长字符串,例如:“Is -a -d”,系统会将它们会分隔成一个个小的子字符串,即”Is”然后被存放在char* argv[ ]这个指针数组中,所以argv[0]=该程序;argv[1]=ls指令,argv[2]=“-a”指令。argc是int型,指的是子字符串的个数。
假如argc数值为10,那么数组从下标1索引处开始会有9个元素指针分别指向9个子字符串。直到argv数组遍历到最后一个元素指针的下一个指针处,发现该指针指向NULL,停止遍历,终止循环。
那么可根据int main中的命令行参数去修改上面那种写法:
针对方法1的写法有2种修改方式,一种是使用argv[i]可以直接做循环的限制条件;另一种就是使用*(argv+i) ——解引用指针位置。
既然我们可以用int main()的命令行参数去获取用户在DOS命令下输入的指令,接下来就是重点了:
那么我们就可以根据用户输入的DOS指令,通过数组去获取用户输入的每一个子字符串,通过这些字符串去执行特定的命令,如下:
通过写好该代码后,编译运行:
结果解析:数组argv[0]获取到该程序的全路径名,argv[1]获取到用户输入的-a选项,根据-a选项可以执行特定的作用。
就好比我们输入ls -a,Shell操作系统也是通过数组argv[0]去获取到ls指令(ls的实现也是代码文件)的路径名,argv[1]获取到-a选项,使用if语句与strcmp比较函数判定,然后执行特定的作用,即显示当前路径下所有的隐藏文件,这就是ls指令下 -a选项的作用。
剩下的案例也是一样的。
使用命令行参数获取并打印部分或者整体环境变量的方法:
方法1:
在int main的命令行参数种,再多加一个char* env[] ,它的类型也是字符指针,该数组中的每一个元素都指向环境变量的一行内容。我们还是利用循环去遍历env数组中的每一个元素,进而获取到环境变量中的所有内容!
运行结果:
方法2:使用外部链接environ:
代码:
运行结果: