目录
前言
依赖
依赖关系
依赖方法
使用
项目清理
在使用 Linux 的时候应该已经察觉到,在 Linux 环境下我们会有非常多的源文件,并且在使用前还需要手动编译,在使用的时候就会变得非常地麻烦。
但 make/Makefile 的出现就解决这些问题, Makefile 定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。 Makefile 带来的好处就是——“自动化编译”,一旦写好,只需要一个 make 命令,整个工程完全自动编译,极大的提高了软件开发的效率。
同时,值得注意的一点是, make 是使用时输入的命令,而 Makefile 是一个文件里面包含了构建编译所需要的一系列规则。
使用 make/Makefile 完成一件事情的前提就是需要正确的依赖关系+正确的依赖方法。
可以简单的理解为,文件1来源于文件2则说明文件1依赖于文件2。例如我要得到可执行文件 text ,在那之前我必须先要有作为源文件的 text.c 才能对其进行编译进而得到 text ,便称 text 依赖于 text.c 。
依赖方法就是在依赖的关系之上将二者进行连接的方法,还是上面的例子,我们知道了 text 依赖于 text.c ,那二者之间的依赖方法就是通过 gcc 进行编译的命令 gcc -o text text.c 了。
为了方便理解将编译链接的各各步骤拆分出来进行讲解。
text:text.o //text依赖于text.o
gcc -o text text.o
text.o:text.s //text.o依赖于text.s
gcc -c -o text.o text.s
text.s:text.i //text.s依赖于text.i
gcc -S -o text.s text.i
text.i:text.c //text.i依赖于text.c
gcc -E -o text.i text.c
- make 会在当前目录下找名字叫 Makefile 或 makefile 的文件(要自己创建)。如果找到,它会找文件中的第一个目标文件,在上面的例子中,他会找到 text 这个文件,并把这个文件作为最终的目标文件。
- 如果 text 文件不存在,或是 text 所依赖的后面的 text.o 文件的文件修改时间要比 text 这个文件新,那么,他就会执行后面所定义的命令来生成 text 这个文件。
- 如果 text 所依赖的 text.o 文件不存在,那么 make 会在当前文件中找目标为 text.o 文件的依赖性,如果找到则再根据那一个规则生成 text.o 文件。(这有点像一个堆栈的过程)
- 你的C文件和H文件是存在的,于是 make 会生成 text.o 文件,然后再用 text.o 文件声明
- make 的最终任务,就是得到可执行文件 text 。
- make 会一层又一层地去找文件的依赖关系,直到最终编译出第一个目标文件。
- 在找寻的过程中,如果出现错误,比如最后被依赖的文件找不到,那么 make 就会直接退出,并报错,而对于所定义的命令的错误,或是编译不成功,make 根本不管。
- make 只管文件的依赖性,即,如果在我找了依赖关系之后,冒号后面的文件还是不在,就会停止运行。
如上的使用make之后会生成 make.i make.s make.o make 四个文件,每次都输入一长串命令去删除未免过于麻烦,可以将删除项目文件也并入 Makefile 之中。
.PHONY: clean
clean:
rm -f text.i text.s text.o
.PHONY 是make/Makefile语法中的一个关键字,代表的意思是:总是被执行的。举个例子,当我们使用 make 生成 text 之后上一次修改 text.c 的时间仍晚于 text 且再次使用 make 则不会生成新的 text 。
[Alpaca@VM-12-9-centos myfile]$ make
gcc -o text text.c
[Alpaca@VM-12-9-centos myfile]$ make
make: `text' is up to date.
[Alpaca@VM-12-9-centos myfile]$ make
make: `text' is up to date.
若是将text也并入 .PHONY 之中这个命令就是总是被执行的,有以下两种写法可以自由选择。
.PHONY: clean text
text:text.o //text依赖于text.o
gcc -o text text.o
text.o:text.s //text.o依赖于text.s
gcc -c -o text.o text.s
text.s:text.i //text.s依赖于text.i
gcc -S -o text.s text.i
text.i:text.c //text.i依赖于text.c
clean:
rm -f text.i text.s text.o
.PHONY: text
text:text.o //text依赖于text.o
gcc -o text text.o
text.o:text.s //text.o依赖于text.s
gcc -c -o text.o text.s
text.s:text.i //text.s依赖于text.i
gcc -S -o text.s text.i
text.i:text.c //text.i依赖于text.c
gcc -E -o text.i text.c
.PHONY: clean
clean:
rm -f text.i text.s text.o
精简之后就是这个样子的。
text:text.c //text依赖于text.c(依赖关系)
gcc -o text text.c //使用gcc对text进行编译链接得到text.c(依赖方法)
.PHONY: clean //clean总是被执行
clean: //clean也是一个文件且不依赖于其他文件(依赖关系)
rm -f text //通过rm删除可执行文件(依赖方法)
在make/Makefile的帮助下可以有效地提升 Linux 的使用效率,好了,这次 make/Makefile 的介绍就到这里结束了,关注博主共同进步!!