GNU Make 中有 7 个核心的自动变量 (automatic variable):
$@:工作目标的文件名
$%:archive文件成员结构中的文件名元素
$<:第一个必要条件的文件名
$?:时间戳在工作目标之后的所有必要条件,并以空格隔开这些必要条件
$^:所有必要条件的文件名,并以空格隔开这些文件名,不包含重复的文件名
$+:同 $^,但包含重复的文件名
$*:工作目标的主文件名,不要在规则以外使用此变量
以上变量都具有两个变体,
1. 附加字母 D 只会返回值的目录部分,例如 $(@D),$(<D)等
2. 附加字母 F 只会返回值的文件部分,例如 $(@F),$(<F)等
可以写一个测试文件验证一下,例如有如下的 makefile:
all: file1.txt file2.txt file1.txt
@echo $@
@echo $<
@echo $?
@echo $^
@echo $+
在我的 shell 中运行结果如下:
lijiangshui@Debian:~$ ls
file1.txt file2.txt makefile
lijiangshui@Debian:~$ make all
all
file1.txt
file1.txt file2.txt
file1.txt file2.txt
file1.txt file2.txt file1.txt
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/lijiangshui/archive/2007/01/24/1492476.aspx