makefile中自動化變數

2021-06-22 00:39:39 字數 2154 閱讀 2336

所謂自動化變數,就是這種變數會把模式中所定義的一系列的檔案自動地挨個取出,直至所有的符合模式的檔案都取完了。這種自動化變數只應出現在規則的命令中。 

下面是所有的自動化變數及其說明: 

$@ 表示規則中的目標檔案集。在模式規則中,如果有多個目標,那麼,"$@"就是匹配於目標中模式定義的集合。 

$% 僅當目標是函式庫檔案中,表示規則中的目標成員名。例如,如果乙個目標是"foo.a(bar.o)",那麼,"$%"就 是"bar.o","$@"就是"foo.a"。如果目標不是函式庫檔案(unix下是[.a],windows下是[.lib]),那麼,其值為空。 

$< 

依賴目標中的第乙個目標名字。如果依賴目標是以模式(即"%")定義的,那麼"$<"將是符合模式的一系列的檔案集。注意,其是乙個乙個取出來的。 

$? 所有比目標新的依賴目標的集合。以空格分隔。 

$^ 所有的依賴目標的集合。以空格分隔。如果在依賴目標中有多個重複的,那個這個變數會去除重複的依賴目標,只保留乙份。 

$+ 這個變數很像"$^",也是所有依賴目標的集合。只是它不去除重複的依賴目標。 

$*  

這個變數表示目標模式中"%"及其之前的部分。如果目標是"dir/a.foo.b",並且目標的模式是"a.%.b",那麼,"$*"的 值就是"dir/a.foo"。這個變數對於構造有關聯的檔名是比較有較。如果目標中沒有模式的定義,那麼"$*"也就不能被推導出,但是,如果目標文 件的字尾是make所識別的,那麼"$*"就是除了字尾的那一部分。例如:如果目標是"foo.c",因為".c"是make所能識別的字尾名,所 以,"$*"的值就是"foo"。這個特性是gnu make的,很有可能不相容於其它版本的make,所以,你應該盡量避免使用"$*",除非是在隱含 規則或是靜態模式中。如果目標中的字尾是make所不能識別的,那麼"$*"就是空值。 

當你希望只對更新過的依賴檔案進行操作時,"$?"在顯式規則中很有用,例如,假設有乙個函式庫檔案叫"lib",其由其它幾個object檔案更新。那麼把object檔案打包的比較有效率的makefile規則是: 

lib : foo.o bar.o lose.o win.o 

ar r lib $? 

在上述所列出來的自動量變數中。四個變數($@、$<、$%、$*)在擴充套件時只會有乙個檔案,而另三個的值是乙個檔案列表。這七個自動化變 量還可以取得檔案的目錄名或是在當前目錄下的符合模式的檔名,只需要搭配上"d"或"f"字樣。這是gnu make中老版本的特性,在新版本中,我們 使用函式"dir"或"notdir"就可以做到了。"d"的含義就是directory,就是目錄,"f"的含義就是file,就是檔案。 

下面是對於上面的七個變數分別加上"d"或是"f"的含義: 

$(@d) 

表示"$@"的目錄部分(不以斜槓作為結尾),如果"$@"值是"dir/foo.o",那麼"$(@d)"就是"dir",而如果"$@"中沒有包含斜槓的話,其值就是"."(當前目錄)。 

$(@f) 

表示"$@"的檔案部分,如果"$@"值是"dir/foo.o",那麼"$(@f)"就是"foo.o","$(@f)"相當於函式"$(notdir $@)"。 

"$(*d)" 

"$(*f)" 

和上面所述的同理,也是取檔案的目錄部分和檔案部分。對於上面的那個例子,"$(*d)"返回"dir",而"$(*f)"返回"foo" 

"$(%d)" 

"$(%f)" 

分別表示了函式包檔案成員的目錄部分和檔案部分。這對於形同"archive(member)"形式的目標中的"member"中包含了不同的目錄很有用。 

"$("$(

分別表示依賴檔案的目錄部分和檔案部分。 

"$(^d)" 

"$(^f)" 

分別表示所有依賴檔案的目錄部分和檔案部分。(無相同的) 

"$(+d)" 

"$(+f)" 

分別表示所有依賴檔案的目錄部分和檔案部分。(可以有相同的) 

"$(?d)" 

"$(?f)" 

分別表示被更新的依賴檔案的目錄部分和檔案部分。 

最後想提醒一下的是,對於"$<",為了避免產生不必要的麻煩,我們最好給$後面的那個特定字元都加上圓括號,比如,"$(<)"就要比"$<"要好一些。 

還得要注意的是,這些變數只使用在規則的命令中,而且一般都是"顯式規則"和"靜態模式規則"(參見前面"書寫規則"一章)。其在隱含規則中並沒有意義。 

makefile自動化變數

makefile自動化變數 表示規則中的目標檔案集。在模式規則中,如果有多個目標,那麼,就是匹配於目標中模式定義的集合。僅當目標是函式庫檔案中,表示規則中的目標成員名。例如,如果乙個目標是 foo.a bar.o 那麼,就是 bar.o 就是 foo.a 如果目標不是函式庫檔案 unix下是 a w...

makefile 自動化變數

代表規則中的目標檔名。如果目標是乙個文件 linux中,一般稱.a檔案為文件 那麼它代表這個文件的檔名。在多目標的模式規則中,它代表的是哪個觸發規則被執行的目標檔名。規則的目標檔案是乙個靜態庫檔案時,代表靜態庫的乙個成員名。例如,規則的目標是 foo.a bar.o 那麼,的值就為 bar.o 的值...

Makefile自動化變數

在上述的模式規則中,目標和依賴檔案都是一系例的檔案,那麼我們如何書寫乙個命令來完成從不同的依賴檔案生成相應的目標?因為在每一次的對模式規則的解析時,都會是不同的目標和依賴檔案。自動化變數就是完成這個功能的。在前面,我們已經對自動化變數有所提涉,相信你看到這裡已對它有乙個感性認識了。所謂自動化變數,就...