两个隐含规则;
- 将所有的
name.o
的依赖自动推导为name.c
并使用规则$(CC) -c $(FLAGS) $(CPPFLAGS)
得到目标。这个规则中只有-c
是隐含规则中有的,后面两个变量是留给用户使用的,如果-c
不够用,可以通过设置他们来改变这条隐含规则,有了这条隐含规则,下面的写法是被允许的
res:main.o fcn.o
.PHONY:clean
clean:
rm *.o
name
目标依赖于name.o
,其生成命令是:$(CC) $(LDFLAGS) name.o $(LOADLIBES) $(LDLIBS)
。这个规则对于多个被依赖的目标文件同样有效,例如:
name : y.o z.o
并且"name.c"、"y.c"和"z.c"都存在,则隐含执行:
cc -c name.c -o name.o
cc -c y.c -o y.o
cc -c z.c -o z.o
cc name.o y.o z.o -o name
rm -f name.o
rm -f y.o
rm -f z.o
隐含规则变量
隐含规则中使用了很多变量,我们可以通过设置这些变量来在一定程度上控制隐含规则,我们可以在Makefile的文件中为这些变量重新赋值,也可以在命令行中传入或者在环境变量中写入。我们还可以通过-R
来取消我们指定的变量的值对隐含规则的作用
AR
函数库打包程序。默认命令是“ar”。
AS
汇编语言编译程序。默认命令是“as”。
CC
C语言编译程序。默认命令是“cc”。
CXX
C++语言编译程序。默认命令是“g++”。
CPP
C程序的预处理器(输出是标准输出设备)。默认命令是“$(CC) –E”。
RM
删除文件命令。默认命令是“rm –f”。
ARFLAGS
函数库打包程序AR命令的参数。默认值是“rv”。
ASFLAGS
汇编语言编译器参数。(当明显地调用“.s”或“.S”文件时)。
CFLAGS
C语言编译器参数。
CXXFLAGS
C++语言编译器参数。
CPPFLAGS
C预处理器参数。( C 和 Fortran 编译器也会用到)。
LDFLAGS
链接器参数。(如:“ld”)