12.自动生成依赖关系(中)---(-MM include sed初探)

本文深入探讨了Makefile中的include关键字作用及其处理方式,并通过实例解释命令执行机制,最后提出了解决依赖文件问题的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1.makefile中的include关键字

2.make对include关键字的处理方式

3.下面的代码怎么执行?为什么?

4.makefile中命令的执行机制

5.下面的代码想要实现的功能?有没有问题?

6.解决方案的初步思路


 

1.makefile中的include关键字

  • 类似C语言中的include
  • 将其他文件的内容原封不动的搬入当前文件

2.make对include关键字的处理方式

  • 在当前目录搜索或指定目录搜索目标文件
  1. 搜索成功:将文件内容搬入当前makefile中
  2. 搜索失败:产生警告

          以文件名作为目标查找并执行对应规则

          当文件名对应的规则不存在时,最终产生错误

3.下面的代码怎么执行?为什么?

如果有test.txt文件,在里面添加一行代码,按照make回去找第一个目标,所以就不会去执行all这个目标

4.makefile中命令的执行机制

  • 规则中的每个命令默认是在一个新的进程中执行(shell)
  • 可以通过接续符(;)将多个命令组合成一个命令
  • 组合的命令依次在同一个进程中被执行
  • set –e指定发生错误后立即退出执行

5.下面的代码想要实现的功能?有没有问题?

并没有达到我们的需求,其实这三条指令:规则中的每个命令默认是在一个新的进程中执行(shell),也就说执行一条就已经结束了。

.PHONY : all

all :
	set -e; \
	mkdir test; \
	cd test; \
	mkdir subtest

6.解决方案的初步思路

  • 通过gcc –MM和sed得到.dep依赖文件(目标的部分依赖)

                      技术点:规则中命令的连续执行

  • 通过include指令包含所有的.dep依赖文件

                      技术点:当.dep依赖文件不存在时,使用规则自动生成

改进,就可以去掉打印出来的两个警告


.PHONY : all clean

MKDIR := mkdir
RM := rm -fr
CC := gcc

SRCS := $(wildcard *.c)
DEPS := $(SRCS:.c=.dep)

-include $(DEPS)

all :
	@echo "all"
	
%.dep : %.c
	@echo "Creating $@ ..."
	@set -e; \
	$(CC) -MM -E $^ | sed 's,\(.*\)\.o[ :]*,objs/\1.o : ,g' > $@
	
clean :
	$(RM) $(DEPS)
	
  • To be continued…

思考:

如何组织依赖文件相关的规则与源码编译相关的规则,进而形成功能完整的makefile程序?

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值