makefile一般格式,自动更新头文件

OBJECT=aaa.o bbb.o
EDIT:$(OBJECT)
	$(CC) $(OBJECT) -o a.out
include $(OBJECT:.o=.d)
%.o:%.c
	$(CC) -c $< -o $@
%.d:%.c
	@set -e;rm -f $@;\
	$(CC) -MM $(CPPFLAGS) $< > $@.$$$$;\
	sed 's,\($*\)\.o[ :]*,\1.o $@:,g' < $@.$$$$ > $@;\
	rm -f $@.$$$$
.PHONY:clean
clean:
	-rm -rf *.o *.d

代码中的aaa.o bbb.o对应.c的源程序,文件名要在3个字母以上。EDIT为默认的第一个目标,生成的可执行文件名为a.out。EDIT后的每一条命令CC在链接阶段执行,include关键字用包含文件,其后用了变量替换规则,将变量OBJECT中的.o替换为.d,最后include将文件名为aaa.d bbb.d的文件中的内容依次包含进来。其中在刚开始时aaa.d文件不存在,那么系统会提示错误,但是系统会尝试从后面的代码中生成.d的文件,%.d:%.c后的命令。生成的aaa.d文件中的内容为aaa.o aaa.d:aaa.c aaa.h,意思是aaa.o aaa.d都要依赖于aaa.c aaa.h,只要.c .d文件中的一个发生变化,那么相应的.o .d也要从后面的代码中重新生成。由于用include新插入了两个.d文件中的内容,那么Makefile会依次执行新插入的内容。.o的文件是从%.o:%.c后生成,.d文件是从%.d:%.c生成。这个文件只要不make clean,那么当每二次make时将不会再提示没有.d文件,因为有了,但是如果.h 或.c的文件被更新,那么仍然会执行%.d:%.c后的命令,因为.d文件中有aaa.o aaa.d两个目标都依赖于.c .h文件
   makefile中,如果左边对应的目标是一个真实的文件,那么,右边的依赖文件变化,必然导致左边的目标文件重新生成,如果左边的目标是一个非文件,那么只有第一个目标会发生改变,需要重新执行命令,生成相应的文件。

makefile左边的目标可以是非文件,也可是一个文件,右边的依赖关系也是。对于右边的非文件目标,只有第一个执行的非文件目标才会执行它后边的命令。

左边的目标中,所有目标都是非文件目标,那么它只执行第一个,只有多个的文件目标,才会依次更新文件目标

上述纯粹是个人的一些总结

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值