規則中的通配符 “*” ,“?” ,“ [...]”, " % " , " wildcard "
1.“*” ?*.c表示所有后綴為.C的文件;
如果文件中用到通配符,使用“\*”;
2.通配符在變量中的使用;
objects=*.c
注意:這里的通配符就是用在變量中的,不過,objects的值就是“*.o”,并不會展開;
如果希望展開的話,可以這么使用:
objects := $(wildcard *.o);
wildcard是Makefile中的關鍵字;
3.Makefile中的自動變量
$@ ?:表示的是$@所在的規則中的所有的目標文件集。
$< ? :依賴目標中的第一個目標名字。
如果依賴目標是以模式(即"%")定義的,那么"$<"將是符合模式的一系列的文件集。注意,其是一個一個取出來的。?
$^ ? ?:?所有的依賴目標的集合。以空格分隔。
如果在依賴目標中有多個重復的,那個這個變量會去除重復的依賴目標,只保留一份。
$? :?所有比目標新的依賴目標的集合。以空格分隔。
$% ? :僅當目標是函數庫文件中,表示規則中的目標成員名。
?例如,如果一個目標是"foo.a(bar.o)",那么,"$%"就是"bar.o","$@"就是"foo.a"。
?如果目標不是函數庫文件(Unix下是[.a],Windows 下是[.lib]),那么,其值為空。?
$+ ?:這個變量很像"$^",也是所有依賴目標的集合。只是它不去除重復的依賴目標。
?