Makefile隐含规则

两个隐含规则;

将所有的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”。 CCC语言编译程序。默认命令是“cc”。 CXXC++语言编译程序。默认命令是“g++”。 CPPC程序的预处理器(输出是标准输出设备)。默认命令是“$(CC) –E”。 RM删除文件命令。默认命令是“rm –f”。 ARFLAGS函数库打包程序AR命令的参数。默认值是“rv”。 ASFLAGS汇编语言编译器参数。(当明显地调用“.s”或“.S”文件时)。 CFLAGSC语言编译器参数。 CXXFLAGSC++语言编译器参数。 CPPFLAGSC预处理器参数。( C 和 Fortran 编译器也会用到)。 LDFLAGS链接器参数。(如:“ld”)

相关推荐