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

29 篇文章 0 订阅

用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$ PATH=$PATH:.
test@btdalvm03:~/c$ unset ttvar
test@btdalvm03:~/c$ echo $ttvar

test@btdalvm03:~/c$ tt.sh
28796
test@btdalvm03:~/c$ echo $ttvar

test@btdalvm03:~/c$


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

01.test@btdalvm03:~/c$ echo $$ 
02.28210 
03.test@btdalvm03:~/c$ echo $$ 
04.28210 
05.test@btdalvm03:~/c$ sh 
06.sh-3.2$ echo $$ 
07.29152 
08.sh-3.2$ bash 
09.bash interactive changed 
10.test@btdalvm03:~/c$ echo $$ 
11.29153 
12.test@btdalvm03:~/c$ ps 
13.  PID TTY          TIME CMD 
14.28210 pts/1    00:00:00 bash 
15.29152 pts/1    00:00:00 sh 
16.29153 pts/1    00:00:00 bash 
17.29205 pts/1    00:00:00 ps 
18.test@btdalvm03:~/c$ exit 
19.exit 
20.sh-3.2$ echo $$ 
21.29152 
22.sh-3.2$ exit 
23.exit 
24.test@btdalvm03:~/c$ echo $$ 
25.28210 
26.test@btdalvm03:~/c$ 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值