Makefile学习之路14 —— 自动生成依赖关系(续)

本文介绍了在Makefile中自动生成依赖关系的方法,包括解决动态改变头文件依赖关系可能导致的编译问题。通过将依赖文件作为目标,利用include关键字,并在规则执行时更新依赖文件,确保了makefile的正确编译决策和移植性。

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

声明:本文写于 狄泰软件学院makefile课程 学后总结,本文版权归狄泰软件学院所有!

 疯狂想法的注意事项:

        当 .dep 文件生成后, 如果动态改变头文件的依赖关系, 那么 make 可能无法检测到这个改变, 进而做出编译决策。

解决方案:

 将依赖文件名作为目标加入自动生成依赖关系中

通过 include 加载依赖文件时判断是否执行规则

在规则执行时重新生成依赖关系文件

最后加载新的依赖文件

 


.PHONY : all clean

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

DIR_DEPS := deps
DIR_EXES := exes
DIR_OBJS := objs

DIRS := $(DIR_DEPS) $(DIR_EXES) $(DIR_OBJS)

EXE := app.out
EXE := $(addprefix $(DIR_EXES)/, $(EXE))

SRCS := $(wildcard *.c)
DEPS := $(SRCS:.c=.dep)
DEPS := $(addprefix $(DIR_DEPS)/, $(DEPS))
OBJS := $(SRCS:.c=.o)
OBJS := $(addprefix $(DIR_OBJS)/, $(OBJS))

all : $(DIR_OBJS) $(DIR_EXES) $(EXE)

ifeq ("$(MAKECMDGOALS)", "all")
-include $(DEPS)
endif

ifeq ("$(MAKECMDGOALS)", "")
-include $(DEPS)
endif


$(EXE) : $(OBJS)
	$(CC) -o $@ $^
	@echo "Success! Target => $@"

$(DIR_OBJS)/%.o : %.c
	$(CC) -o $@ -c $(filter %.c, $^)

$(DIRS) :
	$(MKDIR) $@

ifeq ("$(wildcard $(DIR_DEPS))", "")
$(DIR_DEPS)/%.dep : $(DIR_DEPS) %.c
else
$(DIR_DEPS)/%.dep : %.c
endif
	@echo "Creating $@ ... "
	@set -e; \
	$(CC) -MM -E $(filter %.c, $^) | sed 's,\(.*\)\.o[ :]*,objs/\1.o $@ : ,g' > $@

clean :
	$(RM) $(DIRS)
	
rebuild :
	@$(MAKE) clean
	@$(MAKE) all
	

 

 小结:

  • makefile 中可以将目标的拆分写到不同的地方
  • include 关键字能够触发相应规则的执行
  • 如果规则的执行导致依赖更新, 可能导致再次解释执行相应规则
  • 依赖文件需要依赖源文件得到正确的编译决策
  • 自动生成文件间的依赖关系能够提高makefile的移植性
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值