在shell中,可以使用export修改當前進程的環境變數。例如,
export PATH=.:$PATH
就可以將當前路徑加入可執行檔尋找路徑中,這樣你就不要敲“./excutable” 來執行當前路徑中的excutable。而只需要鍵入 “excutable” 就行了。
make可以執行shell命令,當然也包括export。同時,make本身的文法,也含有export操作符。這樣,在同一個Makefile中,兩個export可能遵循完全不同的文法,shell命令文法和make文法。他們的作用也就完全不同。
1)Makefile中shell版export
小標題的意思是,這裡的export是shell命令。它通常包含在Makefile的規則中,成為某規則的命令列(的一部分)。例如:
init:
export DEBUG=1
……
…
run: init
./myapp
第一條init規則的本意是設定環境變數DEBUG=1(可能作者想讓以後啟動的程式myapps在Debug模式下運行)。但是上述規則沒有起到作者想要的作用:對後來啟動的程式apps來說,DEBUG並沒有改變。原因何在?
首先,上面export行是shell命令;對每一行shell命令,make將啟動一個新的進程執行這行shell命令。由於新啟動的子 進程的環境變數完全跟父進程不相干,因此export並不能改變父進程的環境變數,進而也不能改變父進程以後啟動的子進程,或曰“弟弟進程”的環境變數。
正確的寫法應該是:
run:
export DEBUG=1 && ./myapp
或者:
run:
env DEBUG=1 ./myapp
2)Makefile中make版export
同上,小標題的意思是,這裡的export完全是make文法中的操作符。它通常是用來向後起的make進程(這些後起的make進程由當前的make進程啟動)傳送變數。例如:
recursively_build:
$(MAKE) –c arch/src/ arch=x86_64
而arch變數是檔案arch/src/Makefile中的一個關鍵的開關變數,它將決定哪一種architecture的源檔案將被編譯連結。
為了將變數arch傳遞給將要處理arch/src/Makefile的子make進程,需要用export:
export arch
這裡的export出來的變數arch將被子make進程繼承。
===================
【總結】
1.在(parent,上層的)makefile中export出來變數,子makefile(sub make)中,是可以訪問的。
2. 而同一層級的makefile(可通過makefile中內建變數MAKELEVEL查看得知當前makefile的levlel),是無法通過export來傳遞變數的,即一個makefile中export出來一個變數,同一級的另外一個makefile中,是無法訪問/得到的。
3.makefile中的export是匯出變數到子makfile,而目標對應執行的動作中的export,是屬於shell中的export,其作用是匯出變數到當前shell。此兩個export的作用是不同的。