$@
表示規則中的目標檔案集。在模式規則中,如果有多個目標,那麼,"$@"就是匹配於目標中模式定義的集合。
$%
僅當目標是函式庫檔案中,表示規則中的目標成員名。例如,如果乙個目標是"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)"
分別表示被更新的依賴檔案的目錄部分和檔案部分。
最後想提醒一下的是,對於"$<",為了避免產生不必要的麻煩,我們最好給$後面的那個特定字元都加上圓括號,比如,"$(<)"就要比"$<"要好一些。
Linux之Makefile(變數高階用法)
我們可以替換變數中的共有的部分,其格式是 var a b 或是 其意思是,把變數 var 中所有以 a 字串 結尾 的 a 替換成 b 字串。這裡的 結尾 意思是 空格 或是 結束符 還是看乙個示例吧 foo a.o b.o c.o bar foo o c 這個示例中,我們先定義了乙個 foo 變數...
Linux之Makefile(併發執行命令)
gnu make 支援同時執行多條命令。通常情況下,同一時刻只有乙個命令在執行,下乙個命令只有在當前命令執行完成之後才能夠開始執行。不過可以通過 make的命令 行選項 j 或者 job 來告訴 make 在同一時刻可以允許多條命令同時被執行 注 意,在 ms dos中此選項無效,因為它是單任務作業...
makefile之萬用字元擴充套件
makefile中使用萬用字元的注意點 關於makefile中的萬用字元話題其實很簡單,在使用時心中知道以下幾點就ok。1 makefile中的萬用字元與通常的shell萬用字元是一樣的。萬用字元匹配?任何的單一字元 任何的字元字串 set 任何在set裡的字元 set 任何不在set裡的字元 2 ...