makefile(06)_隐式规则

发布时间:2020-07-15 13:19:13 作者:三九感冒灵
阅读:910
开发者专用服务器限时活动,0元免费领! 查看>>

15.Make的隐式规则

15.1.命令覆盖

问题1:通过各目标的命令拆分写到不同的地方,会发生什么?

.PHONY : all 

VAR := test

all : 
    @echo "all : $(VAR)"

include 1.mk

文件1.mk内容:

all : 
    @echo "this is command from 1.mk"

Makefile中出现同名目标时:
依赖:所有的依赖将合并到一起,成为目标的最终依赖
命令:当多处出现同一目标的命令时,make发出警告,所有之前定义的命令被最后的命令取代。
注意:
当使用include包含其他文件(makefile)时,需要确保被包含的文件中的同名目标只有依赖,没有命令;否则,同名目标的命令将被覆盖!

15.2.隐式规则

Make中提供了一些常用的,例行的规则实现,当目标的规则未提供时,make尝试使用隐式规则
下面的代码可以编译成功吗?为什么?

SRCS := $(wildcard *.c)
OBJS := $(SRCS:.c=.o)

app.out : $(OBJS)
    $(CC) -o $@ $^
    $(RM) $^
    @echo "Target ==> $@"

%.o : %.c
    @echo "my rule"
    $(CC) -c -o $@ $^

根据我们的初步分析,上面的Makefile中存至少两个问题:
1.没有定义CC 和RM变量而直接使用
2.没有定义生成.o文件的规则(只有链接没有编译)
运行结果:
makefile(06)_隐式规则
为什么可以成功运行,原因在于make中的隐式规则。
Make中提供了生成目标文件的隐式规则,会使用预定义变量完成编译工作;
改变预定义变量间部分改变隐式规则的行为,当存在自定义规则时,不再使用隐式规则。

16.Make的隐式规则

16.1.隐式规则的弊端

目标的依赖不存在时,make会尝试通过依赖名逐一查找隐式规则,并通过依赖名推导出可能的源文件。
makefile(06)_隐式规则
这种行为看起来简化了makefile的写法,但可能会带来意想不到的问题。
隐式规则副作用:

16.2.隐式规则的禁用

1.局部禁用:在Makefile中自定义规则,如定义一个只有目标和依赖,没有命令的规则,如:

%.o : %.p

这样就可以使用我们自定义的规则,而非隐式规则
2.全局禁用

make -r

显然这种简单实用,推荐使用

16.3.后缀规则

后缀规则时旧式的“模式规则”,可以通过后缀描述的方式自定义规则
1.双后缀规则:定义一对文件后缀(依赖文件后缀和目标文件后缀)

如: .cpp  <---> %.o : %.cpp

2.单后缀规则:定义单个文件后缀(源文件后缀)

如: .c  <--->  % : %.c

注意:
后缀规则中不允许有依赖,后缀规则必须有命令,否则无意义
已经逐步被模式规则替代,建议直接使用模式规则

亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读:
  1. 师兄U盘启动盘制作工具,支持UEFI+BIOS
  2. nagios 监控xenserver 温度

开发者交流群:

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

makefile 隐式规则 __file__

上一篇:什么是云服务器 ECS

下一篇:DotProject环境搭建

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》
开发者交流群×