码迷,mamicode.com
首页 > 其他好文 > 详细

Makefile自动化变量

时间:2015-06-25 19:22:52      阅读:100      评论:0      收藏:0      [点我收藏+]

标签:

•$@
表示规则中的目标文件集。在模式规则中,如果有多个目标,那么,"$@"就是匹配于目标中模式定义的集合。
•$<
依赖目标中的第一个目标名字。如果依赖目标是以模式(即"%")定义的,那么"$<"将是符合模式的一系列的文件集。注意,其是一个一个取出来的。
•$%
 仅当目标是函数库文件中,表示规则中的目标成员名。例如,如果一个目标是"foo.a(bar.o)",那么,"$%"就是"bar.o","$@"就 是"foo.a"。如果目标不是函数库文件(Unix下是[.a],Windows下是[.lib]),那么,其值为空。
•$^
所有的依赖目标的集合。以空格分隔。如果在依赖目标中有多个重复的,那个这个变量会去除重复的依赖目标,只保留一份。
•$+
很像"$^",也是所有依赖目标的集合。只是它不去除重复的依赖目标。
•$*
表示目标模式中"%"及其之前的部分 
 
 

%.o: %.c foo.h

  $(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $<

.c.o:

  $(CC) -c $(CFLAGS) $(CPPFLAGS) -o $@ $<

等价于

%.o: %.c

  $(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $*.o

Makefile自动化变量

标签:

原文地址:http://www.cnblogs.com/xiaokuang/p/4600518.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!