进入到子进程,进行echo,为什么没有刚刚设置的内容了呢?
解析:
通过env(查看环境变量)与set(查看所有变量),我们知道了环境变量和自定义变量,那二者有什么区别呢?其实这二者的差异在于该变量是否会被子进程所继续引用。那什么是父进程?子进程?这就得要了解一下命令的执行行为了。当你登录Linux并取得一个bash之后,你的bash就是一个独立的进程,被称为PID的就是。接下来你在这个bash下面所执行的任何命令都是由这个bash所衍生出来的,那些被执行的命令就被称为子进程了。比如说A进程如果创建了B进程,A进程就是B进程的父进程,B进程就是A进程的子进程。
如图,我们在原本的bash下面执行另一个bash,结果操作的环境接口会跑到第二个bash去(就是子进程),那原本的bash就会处于暂停的情况(就是sleep)。整个命令运行的环境是实线的部分。若要回到原本的bash去,就只有将第二个bash结束掉(执行exit)。
这个程序概念与变量有什么关系啊?关系可大了!因为子进程仅仅会继承父进程的环境变量,子进程不会继承父进程的自定义变量,所以你原本的bash中的自定义变量进入子进程后就会消失不见,一直到你离开子进程并回到原本的父进程后,这个变量才会又出现。
换个角度来说,如果我能将自定义变量变成环境变量的话,那不就可以让该变量值继续存在于子进程了吗?没错,此时就需要export这个命令了。
使用方法:export 变量名称
问题解决办法:
由此,我们在使用export命令之后,将自定义变量变为环境变量后,进入子进程后使用echo,就可以看见我们设置的内容了。
我们也可以按以下的方式区别环境变量和自定义变量:
环境变量=全局变量 自定义变量=局部变量
补充说明:为什么环境变量的数据可以被子进程所引用呢?
这是内存配置的关系,理论上来说,当启动一个shell,操作系统会分配一记忆块给shell使用,此内存的变量可以让子进程取用。若在父进程利用export功能,可以让自定义变量的内容写到上述的记忆块当中(环境变量)。当加载另一个shell时(即启动子进程,而离开原本的父进程了),子shell可以将父shell的环境变量所在的记忆块导入自己的环境变量块当中。