在Linux中用source,dot(.)和直接用脚本文件名执行shell脚本的区别

瘦欲@ 提交于 2020-01-29 00:49:08

用source,dot(.)的方式执行shell脚本的时候,不产生子进程,shell脚本在当前的shell中运行,shell脚本运行完成后,在shell脚本中声明的变量在当前的shell中是可见的.

直接用脚本文件名的方式执行shell脚本的时候,产生子进程,shell脚本在子进程中运行,shell脚本运行完成后,在shell脚本中声明的变量在当前的shell中是不可见的.

验证过程:

在当前目录下有一个tt.sh的脚本内容如下:

#!/bin/bash
echo $$
ttvar=12345

1.先来看当前的shell的pid:28210

test@ www.linuxidc.com :~/c$ echo $$
28210

2.以source的方式执行tt.sh,脚本打印的pid和当前shell的pid一致,在tt.sh中定义的变量ttvar在脚本执行完成后仍然可以访问.

test@ www.linuxidc.com :~/c$ source tt.sh
28210
test@ www.linuxidc.com :~/c$ echo $ttvar
12345

3.以dot方式执行和source效果一样,先用unset将ttvar变量清除.

test@ www.linuxidc.com :~/c$ unset ttvar
test@ www.linuxidc.com :~/c$ echo $ttvar

test@ www.linuxidc.com :~/c$ . tt.sh
28210
test@ www.linuxidc.com :~/c$ echo $ttvar
12345

4.以脚本文件名称直接运行,要件当前文件夹加入PATH,(或者以./tt.sh指定文件名)

test@ www.linuxidc.com :~/c$ PATH=$PATH:.
test@ www.linuxidc.com :~/c$ unset ttvar
test@ www.linuxidc.com :~/c$ echo $ttvar

test@ www.linuxidc.com :~/c$ tt.sh
28796
test@ www.linuxidc.com :~/c$ echo $ttvar

test@ www.linuxidc.com :~/c$

可以看到这种方式,产生了新的子进程,脚本运行完成后,里面定义的变量对于当前的shell是不可访问的.
在改变sh的时候也是要产生子进程的,通过exit退回到改变之前的sh.

test@ www.linuxidc.com :~/c$ echo $$  
28210  
test@ www.linuxidc.com :~/c$ echo $$  
28210  
test@ www.linuxidc.com :~/c$ sh  
sh-3.2$ echo $$  
29152  
sh-3.2$ bash  
bash interactive changed  
test@ www.linuxidc.com :~/c$ echo $$  
29153  
test@ www.linuxidc.com :~/c$ ps  
  PID TTY          TIME CMD  
28210 pts/1    00:00:00 bash  
29152 pts/1    00:00:00 sh  
29153 pts/1    00:00:00 bash  
29205 pts/1    00:00:00 ps  
test@ www.linuxidc.com :~/c$ exit  
exit  
sh-3.2$ echo $$  
29152  
sh-3.2$ exit  
exit  
test@ www.linuxidc.com :~/c$ echo $$  
28210  
test@ www.linuxidc.com :~/c$  
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!