文章目录
- 前言
- 一、C语言main函数的参数
- 二、环境变量
- 总结
前言
我们在Linux命令行输入命令的时候,一般都会跟上一些参数选项,比如l命令,ls -a -l
。以前我总是觉得这是理所当然的,没深究其本质究竟是什么,今天才终于知道其背后原理究竟什么。
一、C语言main函数的参数
大家都知道C语言一定要有main函数,这是一段程序的入口,那既然main也是函数,那也一定有调用,要传参啊。
其实main函数确实被调用了(不过这不是今天的重点),也可以传参。
今天就要详细谈一下main函数的参数。
int main(int argc, char *argv[])
{}
不知道大家见没见过这中形式的main函数,没见过也没关系,给大家介绍一下这两个参数。
- argv:这是一个字符指针数组,其实里面存储的就是命令后面跟着的一个个参数
- argc:就是指明命令后面跟着几个参数
给大家演示一下:
int main(int argc, char* argv[])
{
int i = 0;
for(; i < argc; i++ )
{
printf("%d: %s\n", i, argv[i]);
}
}
如上一段程序,功能很简单,就是打印这个argv数组里面的内容。
看一下结果:
可以看到其实这个数组里面只有一个元素,即./myproc
然而,我在运行可执行程序的命令后随便加一些参数,这些参数都会被保存到argv数组中去,被本程序打印出来。
其实,看到这里大家或许已经明白了。
其实命令本质上是一个可执行程序的名字,用户输入的参数都被保存在argv数组中,程序内通过查看数组的内容来判断执行哪一段代码,进而产生了不同的功能。
例如,可以给大家写一个简易的计算器命令:
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int main(int argc, char* argv[])
{
// 如果输入的的命令不是4个参数,给出提示信息,直接返回
if(argc != 4)
{
printf("Use error\nUsage: %s op[-add|sub|mul|div] d1 d2\n", argv[0]);
return 1;
}
// 读取操作数
int x = atoi(argv[2]);
int y = atoi(argv[3]);
int result = 0;
// 程序一定有4个命令行参数,第一个是程序名
// 判断操作符,以执行不同的功能
if(strcmp(argv[1], "-add") == 0)
{
result = x + y;
printf("%d+%d=%d\n", x, y, result);
}
else if(strcmp(argv[1], "-sub") == 0)
{
result = x - y;
printf("%d-%d=%d\n", x, y, result);
}
else if(strcmp(argv[1], "-mul") == 0)
{
result = x * y;
printf("%d*%d=%d\n", x, y, result);
}
else if(strcmp(argv[1], "-div") == 0)
{
if( 0 == y ) printf("%d/%d=error! div zero\n", x, y);
else printf("%d/%d=%d\n", x, y, x/y);
}
else
{
printf("Use error, you should use right command line\nUsage: %s op[-add|sub|mul|div] d1 d2\n", argv[0]);
}
}
运行结果如下:
二、环境变量
看到这里可能大家还是有疑问,为什么Linux的终端命令不用加./
,而我写的却需要呢?
首先,我们要知道,运行一个可执行程序首先需要知道它的位置,所以我们需要指明是当前目录下的某个可执行文件。终端命令同样如此,只不过终端命令有默认位置,每次都会到这个位置去寻找是否有这个可执行程序而已。
这个默认位置其实便是环境变量,终端命令的默认环境变量是PATH
,我们可以运行echo $PATH
这个命令查看环境变量,例如,
到这里大家可能已经明白了,想让我们自己写的可执行程序也像命令一样执行,只需要把我们自己写的可执行程序的绝对路径加到PATH后面就可以了,通过执行PATH=$PATH:可执行程序的绝对路径
,例如,
总结
Linux中的的环境变量不止PATH,还有很多其他的一些环境变量,本文就不再赘述了。