前言
一个工程的源文件不计其数,按照不同功能分在若干目录中,如何有规则的处理这些文件,提高开发效率呢?就需要自动化编译工具makefile,make则是一个命令工具,解释makefile中指令的工具。两者搭配使用,完成自动化构建。会不会写makefile,从一个侧面说明了一个人是否具备大型工程的能力。
1 makefile和make的概念
**makefile定义了系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。**makefile带来的好处就是“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。(例如,我们就不需在每个源文件写完后 都 [-gcc 参数] 了。)
make 是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Visual C++中的nmake,Linux下GNU的make。可见makefile成为了一种在工程方面的编译方法。
简而言之,makefile是一个文件,定义了规则;make是一条指令,负责解释规则。两者搭配使用,完成项目的自动化构建。
1.1 示例
我们直接来看一个例子,写一个 .c 文件,打印 " hello world "。
以上,我们通过Linux下vim工具,写了code.c的源文件,如果不使用makefile,那我们就需要在窗口下gcc了
写这么多参数,想必你也烦了,那我们就来看看makefile如何简略这些吧。
首先,我们要先创建一个makefile原件,
其次,我么通过vim工具来编译makefile文件。
这里,我们下部深入理解,下面我们会一一讲解,这知道makefile里面有这些内容即可。
最后我们直接输入系统界面下 make 即可,成功创建code.exe。想要删除,输入make clean。
接下来,依次讲解makefile里面的内容分别代表什么含义。
1.2 依赖关系and 依赖方法
字面含义,即上面的code.exe
依赖code.c
;而gcc…就是对用的依赖关系。依赖关系可以有多行。依赖文件列表按空格分开,可以为空。
2 项目清理
工程是需要处理的,像clean这种,**没有被第一个目标文件直接管理或间接关联,那么它后面所定义的命令就不会被自动执行。**不过,我们可以显示要make执行,即命令,make clean
以此来清除所有的目标文件,已重新编译。但一般这种clean的目标文件,设置为伪目标,即 .PHONY 修饰,伪目标特性是,总是被执行。如果我们已经make创建了文件,就不不能再次创建了。
3 make 工作原理
● make会在当前目录下找名字为**“Makefile”** 或 **“makefile”**的文件。
● 如果找到,它会找第一个目标文件,在上面例子中,他会找code.exe这个文件,并把这个文件当做最终的目标文件。(最终目标文件必须是第一个,其他的可以乱序。)
● 如果code.exe不存在,或是code.exe所依赖的后面的code.c文件的修改时间要比code.exe文件新,那么,他就会执行后面所定义的命令来生成code.exe文件。
● 如果code.c不存在,make就会往下寻找,再检查目
● 这就是整个make的依赖性,make会一层又一层的去找文件的依赖关系,直到最后编译出第一个目标文件。
● 在寻找过程中,如果出现错误,比如最终找不到依赖文件,那么make就会直接退出,并报错。而所定义的命令错误,或是编译不成功,make不管。make只管文件的依赖。
4 扩展
**(1)可以使用操作符代替。**例如,$ : 提取的意思;@:目标文件;^:依赖文件
(2)支持变量;
(3)命令前加@,可以隐藏显示
i.下面是不加@符号时,要打印依赖方法。
ii.下面是加@符号后,不打印依赖方法。
总结
以上,就是本期【Linux杂货铺】的所有内容了,讲解了makefile和make的基本使用方法,及其原理。makefile就是指定的规则的文件,make就是负责解释该规则的命令。
文章已获作者授权转载,版权归原作者所有,如有侵权,与本账号无关,可联系删除。 原文作者:秋刀鱼的滋味@
原文链接:https://blog.csdn.net/jupangMZ/article/details/135936805