环境变量
什么是环境变量
我们所有写的程序都需要指定路径才能运行,就像这样:(程序里面是打印DLC循环)
生成的etv是一个可执行程序,但是我们平时使用的指令比如 ls 等等也都是可执行程序,但是并不需要指定目录在哪里才可以使用。
如果将刚才写的etv程序拷贝到/usr/bin 会不会与ls一样可以直接使用?
这样是可以的,但是非常不建议,因为这个程序相当于安装到了系统中,Linux下拷贝就是安装。
那么系统是如何找到的,是因为有一个环境变量——PATH,他在全局都是有效的,是系统默认的指令搜索路径(想查看前面加$):
这是查看PATH环境变量中的内容,用 : 隔开的是不同路径。
添加路径:
只不过这样也就等于把原来的路径覆盖了,只剩下的/home/mfc这个目录了,也就等于在想执行 sl 这种就需要取指定目录才可以。
不过不用担心,重新登陆Linux就可以了,因为这是内存上的改变。
那么我们需要保留原来的并且再添加新的:
这样也不会影响原来的sl等。
在打开Linux的时候bash因为要处理用户的命令,这些命令也是程序,运行程序需要指定路径,所以操作系统就提前将这些指令的路径放在了专属的配置文件,在启动操作系统时将这个文件导入内存中形成一个内存级变量,这就是环境变量。
那么最开始的环境变量是怎么来的呢?
这两个文件里面内容是脚本,内容就是将环境变量导入当前的shell中(这个环境变量是内存级的)。
常见环境变量
HOME 当前用户的工作目录
HOSTNAME 当前主机名
LOGNAME 当前用户名
HISTSIZE 显示储存多少命令内容(历史输入的命令,有一个命令可以查看历史输入的命令,history)
环境变量相关命令
echo: 显示某个环境变量值(记得加$)
export: 设置一个新的环境变量
env: 显示所有环境变量
unset: 清除环境变量
set: 显示本地定义的shell变量和环境变量
环境变量的全局属性
我们也可以定义本地变量:
但是本地变量是无法被子进程继承,我们用一段代码来验证:
参数是定义的变量,如果有这个环境变量就返回一个数值,没有就返回空指针。
这是因为我们刚才定义的变量是在bash上的,bash是一个系统进程,我们的etv是一个可执行文件,运行起来也是一个进程,就是bash的子进程,刚才定义的变量也叫本地变量,不具有全局属性,所以没有传到etv进程里面,就像C语言当中的全局变量和局部变量一样。
这里将本地变量变成环境变量。
环境变量是具有全局属性的,会被子进程继承下去。
PWD
执行可执行程序在当前路径是需要带路径的,但是ls并不需要,这是为什么呢?
因为有一个环境变量PWD是当前路径:
上面我们知道了环境变量会被子进程继承,ls是bash的子进程,所以继承了这个环境变量,就知道了当前路径,所以可以这样执行命令:
main函数的三个参数
在调用某个程序的时候是调用main函数然后才开始运行,那么我们在调用某个程序的时候会带选项,其实这些选项就是前两个参数,第三个参数就是环境变量的参数。
argc是代表有多少个选项,argv[]是一个指针数组,里面是char*,储存的就是程序名与选项,env[]是储存环境变量的指针数组。
先来看看argv与argv[]:
对着这段命令行解析是这样的:
这个过程是由shell和系统来完成的。
这时就平时带选项程序是如何完成各个功能的原因。
然后来看看第三个参数:
这里就是环境变量了。