在Linux中用source,dot(.)和直接用脚本文件名执行shell脚本的区别
用source,dot(.)的方式执行shell脚本的时候,不产生子进程,shell脚本在当前的shell中运行,shell脚本运行完成后,在shell脚本中声明的变量在当前的shell中是可见的.
直接用脚本文件名的方式执行shell脚本的时候,产生子进程,shell脚本在子进程中运行,shell脚本运行完成后,在shell脚本中声明的变量在当前的shell中是不可见的.
验证过程:
在当前目录下有一个tt.sh的脚本内容如下:
echo $$
ttvar=12345
1,先来看当前的shell的pid:28210
test@btdalvm03:~/c$ echo $$
28210
2,以source的方式执行tt.sh,脚本打印的pid和当前shell的pid一致,在tt.sh中定义的变量ttvar在脚本执行完成后仍然可以访问.
test@btdalvm03:~/c$ source tt.sh
28210
test@btdalvm03:~/c$ echo $ttvar
12345
3,以dot方式执行和source效果一样,先用unset将ttvar变量清除.
test@btdalvm03:~/c$ unset ttvar
test@btdalvm03:~/c$ echo $ttvar
test@btdalvm03:~/c$ . tt.sh
28210
test@btdalvm03:~/c$ echo $ttvar
12345
4以脚本文件名称直接运行,要件当前文件夹加入PATH,(或者以./tt.sh指定文件名)
test@btdalvm03:~/c$ echo $$28210test@btdalvm03:~/c$ echo $$28210test@btdalvm03:~/c$ shsh-3.2$ echo $$29152sh-3.2$ bashbash interactive changedtest@btdalvm03:~/c$ echo $$29153test@btdalvm03:~/c$ ps PID TTY TIME CMD28210 pts/1 00:00:00 bash29152 pts/1 00:00:00 sh29153 pts/1 00:00:00 bash29205 pts/1 00:00:00 pstest@btdalvm03:~/c$ exitexitsh-3.2$ echo $$29152sh-3.2$ exitexittest@btdalvm03:~/c$ echo $$28210test@btdalvm03:~/c$