華清遠見嵌入式學院
講師。所謂偽目標就是這樣乙個目標,它不代表乙個真正的檔名,在執行make時可以指定這個目標來執行其所在規則定義的命令,有時我們將乙個偽目標成為標籤。
那麼到底什麼是偽目標呢?可能作為初學者還不會在乎這個問題,下面我們來看下我們將在什麼時候需要它。
首先來看下面乙個例子:
當前目錄下只有乙個myls1.c,於是為了讓程式讓makefile來管理,寫了乙個如下的簡單的makefile。
執行:
大家會發現,真的可以利用這個makefile管理當前的工程,也能如期按照我們的要求生成執行檔案myls。
執行make clean,這樣就可以刪除可執行程式。
接著我做了個手腳,在當前目錄下建立乙個叫clean的檔案,那麼這樣執行的效果是如何?
那麼這個時候為什麼又不能執行了?在我的makefile中其實並沒有修改任何東西,為什麼這個時候已經能管理工程的makefile又不能來管理檔案了。
那要解決這個問題就是新增兩行,修改後的makefile如下:
再次返回執行:
這樣就解決了問題,那具體的原因是什麼?
在makefile中我們使用偽目標就可以解決上述的問題,那為什麼要使用偽目標,一種就是如例題,為了避免在makefile中定義的只執行命令的目標和工作目錄下的實際檔案出現名字衝突,另一種是提交執行makefile時的效率。
第一種情況:
如果我們需要書寫這樣的乙個規則:規則所定義的命令不是去建立目標檔案,而是通過make命令列明確指定它來執行一些特點的命令,就像例題中的clean。當資料夾中沒有clean這個檔案的時候,我們輸入「make clean」能按照初衷執行,但是一旦資料夾中出現clean檔案,我們再次輸入「make clean」,由於這個規則沒有任何依賴檔案,所以目標被認為是最新的而不去執行規則所定義的命令。所以rm命令不會被執行。為了解決問題,我們將目標clean定義成偽目標。
也就是新增:
.phony:clean
那麼目錄中不論是否有clean檔案,只要輸入「make clean」就能執行rm命令了。
當乙個目標被宣告為偽目標後,make在執行規則時不會去試圖去查詢隱含規則來建立它。這樣就提高了make的執行效率,也不用擔心由於目標和檔名重名了。
第二種情況:
偽目標的另一種使用場合時在make的並行和遞迴執行過程中。
給了例子:
subdirs=foo bar baz
subdirs:
for dir in $(subdirs)
do$(make) –c $$dir
done
如果這樣寫,會出現幾個問題:
1、 當子目錄執行make出現錯誤,make不會退出;
2、 使用這種shell的迴圈方式時,沒有用到make對目錄的並行處理功能。
有了偽目標就可以解決上面的兩個問題。
subdirs=foo bar baz
.phony:subdirs $(subdirs)
subdirs: $(subdirs)
$(subdirs):
$(make) –c $@
一般情況下,乙個偽目標不作為另乙個目標的依賴。當乙個偽目標沒有作為任何目標的依賴時,我們只能通過make命令來明確指定它為make的終極目標,來執行它所在規則所定義的命令。
還有乙個特別的偽目標——all,如果我們在乙個目錄下建立多個可執行程式,我們可以將所有程式的重建規則在乙個makefile中描述。
all: p1 p2 p3
p1:p1.c
p2:p2.c
p3:p3.c
www.farsight.com.cn
)
makefile中偽目標詳解
偽目標 下面解釋make是如何工作的 1 當遇到目標體clean時,make先檢視其是否有依賴體,因為clean沒有依賴體,所以make認為目標體是最新的而不執行任何操作.為了編譯這個目標體,必須輸入make clean.2 輸入make clean,此時假設該目錄下面不存在名為clean的檔案,那...
makefile之偽目標
偽目標的目的不是根據依賴關係生成某個目標,而是為了執行某種任務 clean rm o 通過 make clean來使用目標小結 1.因為我們並不是生成clean這個檔案,因此 偽目標 並不是乙個檔案,只是乙個標籤。2.由於 偽目標 不是檔案,所以 make 無法生成它的依賴關係和決定它是否要執行,因...
makefile學習筆記 書寫規則 偽目標
20180416 makefile學習筆記 書寫規則 偽目標 下面的例子中的乙個 clean 的目標,就是乙個 偽目標 clean rm o temp clean的作用是當我們生成了許多編譯檔案時,我們應該提供乙個清楚他們的 目標 以備完整地重編譯而用 以 make clean 來使用該目標 因為,...