fork是最普通的, 就是直接在指令碼裡面用/directory/script.sh來呼叫script.sh這個指令碼.
執行的時候開乙個sub-shell執行呼叫的指令碼,sub-shell執行的時候, parent-shell還在。
sub-shell執行完畢後返回parent-shell. sub-shell從parent-shell繼承環境變數.但是sub-shell中的環境變數不會帶回parent-shell
exec與fork不同,不需要新開乙個sub-shell來執行被呼叫的指令碼. 被呼叫的指令碼與父指令碼在同乙個shell內執行。但是使用exec呼叫乙個新指令碼以後, 父指令碼中exec行之後的內容就不會再執行了。這是exec和source的區別
與fork的區別是不新開乙個sub-shell來執行被呼叫的指令碼,而是在同乙個shell中執行. 所以被呼叫的指令碼中宣告的變數和環境變數, 都可以在主指令碼中得到和使用.
可以通過下面這兩個指令碼來體會三種呼叫方式的不同:
1.sh
#!/bin/bash2.sha=becho "pid for 1.sh before exec/source/fork:$$"
export a
echo "1.sh: \$a is $a"
case $1 in
exec)
echo "using exec…"
exec ./2.sh ;;
source)
echo "using source…"
. ./2.sh ;;
*) echo "using fork by default…"
./2.sh ;;
esac
echo "pid for 1.sh after exec/source/fork:$$"
echo "1.sh: \$a is $a"
#!/bin/bashecho "pid for 2.sh: $$"
echo "2.sh get \$a=$a from 1.sh"
a=cexport a
echo "2.sh: \$a is $a"
執**況:
$ ./1.sh
pid for 1.sh before exec/source/fork:5845364
1.sh: $a is b
using fork by default…
pid for 2.sh: 5242940
2.sh get $a=b from 1.sh
2.sh: $a is c
pid for 1.sh after exec/source/fork:5845364
1.sh: $a is b
$ ./1.sh exec
pid for 1.sh before exec/source/fork:5562668
1.sh: $a is b
using exec…
pid for 2.sh: 5562668
2.sh get $a=b from 1.sh
2.sh: $a is c
$ ./1.sh source
pid for 1.sh before exec/source/fork:5156894
1.sh: $a is b
using source…
pid for 2.sh: 5156894
2.sh get $a=b from 1.sh
2.sh: $a is c
pid for 1.sh after exec/source/fork:5156894
1.sh: $a is c
$
shell載入呼叫另乙個指令碼方法
在linux平台上開發,經常會在console 控制台 上執行另外乙個指令碼檔案,經常用的方法有 my.sh 或 source my.sh 或 my.sh 這三種方法有什麼不同呢?我們先來了解一下在乙個shell指令碼中如何呼叫另外乙個shell指令碼,其方法有 fork exec source。1...
shell指令碼中呼叫另乙個指令碼的三種不同方法
1 fork fork directory script.sh fork是最普通的,就是直接在指令碼裡面用 directory script.sh來呼叫script.sh這個指令碼.執行的時候開乙個sub shell執行呼叫的指令碼,sub shell執行的時候,parent shell還在。sub...
Java中在乙個方法中呼叫另乙個方法
在同乙個類中 對於靜態方法,其他的靜態或非靜態方法都可以直接呼叫它。而對於非靜態方法,其他的非靜態方法是可以直接呼叫它的。但是其他靜態方法只有通過物件才能呼叫它。靜態方法不能被非靜態方法覆蓋。public class test2 public void say1 public void say pu...