(修改日期比目标创建时间新)
$* 目标文件名称(略去扩展名)
$@ 目标文件名称
2.3.通配符
允许在规则中使用通配符,支持三种通配符:“*”、“%”、“?”、“[]”。例子见2.4节
2.4.规则
常见规则
规则有时常常简化,分别称为隐含规则、后缀规则、模式规则。
  1.隐含规则
c程序中,由 .c 生成 .o 文件时,在未给出命令时,由 make 自动添加。
 1 
 hello:hello.o<br>hello.o:hello.c
生成目标文件时,依赖是个头文件
 1 
 fint.o:find.h tom.h
目标文件是个伪目标,“make clean”、“make install”命令执行时激活伪目标。
 1 
 clean:<br>        rm -f *.o<br>install:<br>        install -oview -gview -m700 -T *.out dest/bin/hello<br>        install -oview -gview -m700 -t dest/lib lib*.so lib*.a
2.后缀规则
定义了将具有某后缀的文件转换为具有另外后缀的文件的方法。
 1 
 # .c 文件转换为 .o 文件<br>.c.o:<br>        gcc -c $<
3.模式规则
定义了一类具有相同行为特点的规则,%表示通配。
 1 
 %.o:%.c<br>        $(CC) -c $< -o $@
如此,改写规则文件
 1 
 %.o:%c<br>        $(CC) -c $< -o $@<br>OBJS=hello.o<br>hello:$(OBJS)<br>        gcc -o $@ $^<br>hello.o:hello.c<br>clean:<br>        rm -f *.o
2.5.搜索路径
处理的文件较多时,目录结构较复杂。当需要推导文件的依赖关系时,又需要指明路径。make 的解决方法是,提供一个供搜索的路径,不必指明目录信息。设置一个 VPATH 变量,若当前目录没有找到文件时,就去搜索该变量的路径信息。
VPATH := $(srctree)$(if $(KBUILD_EXTMOD),:$(KBUILD_EXTMOD)) export srctree objtree VPATH
2.6.显示命令
打印一些信息到屏幕……
[linuxidc.com@linuxidc ~]$ sed -n -e '115p' -e '131,132p' -e '176,177p' Makefile # 显示部分内容 begin: @echo -e "Begin Pretreatment...\n" # 显示信息、打印空行 @sleep 1 @echo -e "Begin Compile...\n" # 显示信息、打印空行 @sleep 1 [linuxidc.com@linuxidc ~]$ make begin # 展示部分内容的效果 Begin Pretreatment... Begin Compile... Begin Link... [linuxidc.com@linuxidc ~]$
2.7.保守赋值
Makefile 文件中
 1 
 vpath = include
普通赋值
 1 
 vpath := include
避免变量递归赋值
 1 
 vpath ?= include
首次定义的变量才会被赋值
 1 
 vpath += include
追加变量的值
3.创建和使用函数库

