https://blog.csdn.net/szullc/article/details/85038875
在上一篇 《【Linux + Makefile】十分钟教你学会Makefile的FORCE 》文章的最后,笔者就FORCE的用法在一个示例工程中使用,提出了一个问题:为何build_info.h每次都是新生成的(有修改过),而main.c又是有include “build-info.h”,但main.c却不是每次都重新编译呢?这个到底是不是违反了Makefile的基本规则呢?本文将给你答案,通过阅读本文,你将了解到以下内容:
如何保证在C文件中包含的头文件修改了的时候,C文件每次都会被重新编译?
为了更好地展示上诉描述的问题,我们将之前的示例工程稍微复杂化一点点:
整个工程有3个.c文件,a.c/b.c/main.c,其中main.c会调用a.c/b.c中的两个接口,同时main.c会include头文件build_info.h;这个build_info.h每次编译都会重新生成,按照我们之前的写法,我们Makefile可能就是这样:
SHELL = /bin/bash #指定shell使用/bin/bash,否则echo -e可能会出问题
ECHO = echo
BIN = test
BUILG_INFO_H = build_info.h
SRC-C-y += a.c
SRC-C-y += b.c
SRC-C-y += main.c
SRC-O = $(patsubst %.c, $(O)%.o,