感谢支持
我们一直在努力

Makefile隐含规则

Makefile两个隐含规则;

  1. 将所有的name.o的依赖自动推导为name.c并使用规则$(CC) -c $(FLAGS) $(CPPFLAGS)得到目标。这个规则中只有-c是隐含规则中有的,后面两个变量是留给用户使用的,如果-c不够用,可以通过设置他们来改变这条隐含规则,有了这条隐含规则,下面的写法是被允许的

    res:main.o fcn.o
    .PHONY:clean
    clean:
    rm *.o
  2. 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”)

本文永久更新链接地址:http://www.linuxidc.com/Linux/2016-10/136057.htm

赞(0) 打赏
转载请注明出处:服务器评测 » Makefile隐含规则
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏