这篇文章主要讲的是关于如何自己构建一个Makefile。
目录
1.依赖关系
首先要明确各文件之间的依赖关系。比如说一个.c的源文件要经过怎样的处理才能变成一个可执行程序。答案是预处理,编译,汇编,链接。.c->.i->.s->.o->.exe不同的过程有不同的依赖关系和依赖方法。-E是只预处理。-S是预处理+编译。-c是预处理+编译+汇编。-o是预处理+编译+汇编+链接。

在makefile中文件的依赖关系是倒着找的,也就是说要先写.exe和.o之间的依赖关系和依赖方法,最后写.i和.c的。具体如下 第一行写依赖关系,第二行写依赖方法。

2.变量定义
上面的方法只能用于一个文件,如果要使用到其他文件中就要改变很多地方,所以使用变量来解决这个问题。方法如下

31行和32行是变量定义的过程。$(变量名)是拿到变量所指向的数据,33行$(BIN)=test.exe,$(SRC)=test.c。echo相当于打印,前面加@是为了防止方法回显在屏幕上。
3.伪目标
伪目标就是总是可以被执行的一条指令,方法如下

.PHONY: 命令名称
4.拓展

这是一段完整的自动化构建代码。
这些方法的格式尤其要注意,比如说第2行wildcard和*.c之间的空格就不能省略,意思是获取当前目录下所有后缀为.c的文件,第3行表示将所有的后缀.c改成.o,只是进行字符替换生成目标文件名列表。第13行的是真正的将.c文件一个一个展开进行预处理,编译,汇编成机器码,再交给第9行生成可执行程序。
$(变量名):获取变量名指向的内容
*.c:表示目录下所有后缀为.c的文件
@:取消回显
$@:目标文件
$^:依赖文件
$<:表示第一个依赖文件的名称
%.o:%.c:表示一种依赖关系,当需要.o时说明它依赖于.c
“继续加油!”
13万+

被折叠的 条评论
为什么被折叠?



