Makefilr概念

makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。
GCC 工作流程:预处理——编译——汇编——链接
Makefile 工作原理:由依赖文件生成目标文件
.C文件——.i文件——.S文件——.O文件——可执行文件

而Makefile的原理与java中的c3P0池、JDBC的使用原理类似,都是通过将常用变量定义在一个文件中,在使用这些重复变量时直接调用该文件夹,大大减少了用户的时间,提高了工作效率。
你可能会碰到以下三个变量:$@,$^,$<代表的意义分别是:
$@--目标文件,
$^--所有的依赖文件,
$<--第一个依赖文件。
Makefile并不会关心命令是如何执行的,仅仅只是会去执行所有定义的命令,和我们平时直接输入命令行是一样的效果。
1、目标即要生成的文件。如果目标文件的更新时间晚于依赖文件更新时间,则说明依赖文件没有改动,目标文件不需要重新编译。否则会进行重新编译并更新目标文件。
2、默认情况下Makefile的第一个目标为终极目标。
3、依赖:即目标文件由哪些文件生成。
4、命令:即通过执行命令由依赖文件生成目标文件。注意每条命令之前必须有一个tab保持缩进,这是语法要求(会有一些编辑工具默认tab为4个空格,会造成Makefile语法错误)。
5、all:Makefile文件默认只生成第一个目标文件即完成编译,但是我们可以通过all 指定所需要生成的目标文件。



629

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



