makefile自動變數

2022-09-16 06:54:13 字數 2362 閱讀 9397

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

$@

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

目標中模式定義的集合。

$%

僅當目標是函式庫檔案中,表示規則中的目標成員名。例如,如果乙個目標是"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自動化變數

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