您的位置:首页 > 其它

Makefile自动变量

2015-08-23 21:54 288 查看
所谓自动化变量,就是这种变量会把模式中所定义的一系列文件自动挨个取出,直至所有符合模式的文件
都取完。自动化变量只应出现在规则的命令中。
下面是所有的自动化变量及其说明:

$@
表示规则中的目标文件。如果目标中有函数库文件,则代表目标中的函数库文件。

$%
当目标中有函数库文件时使用,表示目标中的非函数库成员。例如,如果一个目标是"foo.a(bar.o)",那么
,"$%"就是"bar.o","$@"就是"foo.a"。如果目标中没有函数库文件,其值为空。

$<
依赖目标中的第一个目标名字。如果依赖目标是以模式(即"%")定义的,那么"$<"将是符合模式的一系
列的文件集。注意,其是一个一个取出来的。

$?
所有比目标新的依赖目标的集合,以空格分隔。

$^
所有依赖目标的集合,以空格分隔。如果在依赖目标中有重复的,这个变量会去除重复的依赖目标,只保
留一份。

$+
这个变量很像"$^",也是所有依赖目标的集合,只是它不去除重。

$*
这个变量表示目标模式中"%"及其之前的部分。如果目标是"dir/a.foo.b",且目标的模式是"a.%.b",那么
,"$*"的值就是"dir/a.foo"。如果目标中没有模式的定义,那么"$*"就不能被推导出。但是,如果目标文件
的后缀是make所识别的,那么"$*"就是除了后缀的那一部分。例如:如果目标是"foo.c",因为".c"是make
能识别的后缀名,所以,"$*"的值就是"foo"。如果目标中的后缀是make所不能识别的,那么"$*"就是空值
。这个特性是GNU make的,很有可能不兼容于其它版本的make,所以,应该尽量避免使用"$*"。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: