shell 與 export命令
用戶登錄到Linux系統后,系統將啟動一個用戶shell。在這個shell中,可以使用shell命令
或聲明變量,也可以創建並運行shell腳本程序。運行shell腳本程序時,系統將創建一個子shell。
此時,系統中將有兩個shell,一個是登錄時系統啟動的shell,另一個是系統為運行腳本程序創建
的shell。當一個腳本程序運行完畢,腳本shell將終止,返回到執行該腳本之前的shell。
從這種意義上來說,用戶可以有許多 shell,每個shell都是由某個shell(稱為父shell)派生的。
在子shell中定義的變量只在該子shell內有效。如果在一個shell腳本程序中定義了一個變量,
當該腳本程序運行時,這個定義的變量只是該腳本程序內的一個局部變量,其他的shell不能引用它,
要使某個變量的值可以在其他shell中被改變,可以使用export命令對已定義的變量進行輸出。
export命令將使系統在創建每一個新的shell時,定義這個變量的一個拷貝。
這個過程稱之為變量輸出。
[例]
在本例中,變量myfile是在dispfile腳本程序中定義的。
然后用export命令將變量myfile輸出至任何子shell,例如當執行printfile腳本程序時產生的子shell。
dispfile腳本程序清單:
myfile=”List”
export myfile
echo “Displaying $myfile”
pr –t –n $myfile
printfile
printfile腳本程序清單:
echo “Printing $myfile”
lpr $myfile&
運行結果:
$dispfile
Displaying List
1 screen
2 modem
3 paper
Printing List
$
export 功能說明:設置或顯示環境變量。
語 法:export [-fnp][變量名稱]=[變量設置值]
補充說明:在shell中執行程序時,shell會提供一組環境變量。export可新增,修改或刪除環境變量,供后續執行的程序使用。export的效力僅限於該次登陸操作。
參 數:
-f 代表[變量名稱]中為函數名稱。
-n 刪除指定的變量。變量實際上並未刪除,只是不會輸出到后續指令的執行環境中。
-p 列出所有的shell賦予程序的環境變量。
從學習export命令理解到的Shell環境和變量生存期
最近在學習BASH的export命令時碰到了一個難道(書上說export是將自定義變量變成
系統環境變量):我在一個腳本文件中定義一個了變量,然后export變量,按照我自己的想法,
執行完這個腳本后,在提示符下一定可以用echo顯示出它的值,可結果卻不是這樣,腳本執行完后
用set根本看不到有這個變量存在。為什么呢?我百思不得其解,最后將問題貼出來,一位前輩告訴
我說用source+腳本文件就可以了,我試了一下果然可以,但一個新的問題又出來了。我將腳本中
export命令刪除后,用source一樣可以。那這個export好像沒有什么用呀。
在經過多次嘗試后發現了一些東西,是我自己猜的,如果有什么不對的地方,請指正,謝謝。
執行一個腳本時,會先開啟一個子shell環境(不知道執行其它程序是不是這樣),然后將父
shell中的所有系統環境變量復制過來,這個腳本中的語句就在子shell中執行。(也就是說父shell
的環境變量在子shell中可以調用,但反過來就不行,如果在子shell中定義了環境變量,只對該shell
或者它的子shell有效,當該子shell結束時,也可以理解為腳本執行完時,變量消失。)
為了證明這一點,請看腳本內容:
test='value'
export test
這樣的腳本執行完后,test實際上是不存在的。接着看下面的:
test='value'
export test
bash
這里在腳本最后一行再開一個子shell,該shell應該是腳本文件所在shell的子shell,這個腳本
執行完后,是可以看到test這個變量的,因為現在是處於它的子shell中,當用exit退出子shell后,
test變量消失。
如果用source對腳本進行執行時,如果不加export,就不會在子shell中看到這個變量,
因為它還不是一個系統環境變量呀,如腳本內容是:
test='value'
用source執行后,在shell下是能看到這個變量,但再執行bash開一個子shell時,test是不會
被復制到子shell中的,因為執行腳本文件其實也是在一個子shell中運行,所以我再建另一個腳本
文件執行時,是不會輸入任何東西的,內容如:echo $test。所以這點特別注意了,明明在提示符
下可以用echo $test輸出變量值,為什么把它放進腳本文件就不行了呢?
所以得出的結論是:
1、執行腳本時是在一個子shell環境運行的,腳本執行完后該子shell自動退出;
2、一個shell中的系統環境變量會被復制到子shell中(用export定義的變量);
3、一個shell中的系統環境變量只對該shell或者它的子shell有效,該shell結束時變量消失
(並不能返回到父shell中)。
3、不用export定義的變量只對該shell有效,對子shell也是無效的。
整理了一下貼子:為什么一個腳本直接執行和用source執行不一行呢?這也是我自己碰到的一個問題。manual原文是這樣的:
Read and execute commands from filename in the current shell environment and
return the exit status of the last command executed from filename.
明白了為什么不一樣了吧?直接執行一個腳本文件是在一個子shell中運行的,而source則是在
當前shell環境中運行的。根據前面的內容,你也已經明白其中的道理了吧。