个人内容简介:
🍃个人主页:诉清风2023
🎈逆转时间的公式,就是珍惜现在ദ്ദി˶ー̀֊ー́ ) ✧
前言
注意
make是命令!!!
makefile是文件!!!
重点
makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译, 极大的提高了软件开发的效率
1、概述
make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令, 比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。
Makefile 是一个文本文件,它包含了一系列规则,这些规则告诉 make工具如何编译和链接程序。Makefile 是 Unix 和类 Unix 系统(包括 Linux)中自动化构建过程的核心组成部分。它允许开发者定义一系列的编译和链接步骤,以及这些步骤之间的依赖关系,从而简化了构建复杂软件项目的过程。
2、实例
- 说那么多概念没有什么作用,我们直接上例子来看看make与makefile的用处
2.1 一般情况下对3个.c文件进行编译链接
(1)假定我们有3个.c的code文件
- code1.c "this is code1文件"
- code2.c "this is code2文件"
- code3.c "this is code3文件"
(2)对三个文件进行编译和链接
我们可以发现,对这3个文件进行编译链接十分繁琐,都是同样的操作,能否有什么简洁明了的方法来对它们进行编译链接呢?
2.2 使用make与makefile来对3个.c文件进行编译链接
(1)创建makefile文件
(2)在makefile中写入命令
由此可见我们的make使用起来确实会方便很多,那么接下来我们开始详细拆析makefile
3、解析makefile
3.1 Makefile的规则
target(要生成的文件): dependencies(被依赖的文件)
#命令前面用的是“tab”而非空格。
command1
command2
.
.
.
commandn
#反斜杠(\)是换行符的意思。可以使用“\”表示续行。注意,“\”之后不能有空格!
- target 也就是一个目标文件,可以是 Object File,也可以是执行文件。还可以是一个标签 (Label),对于标签这种特性,在后续的“伪目标”章节中会有叙述。
- dependencies就是,要生成那个 target 所需要的文件或是目标。即生成target所需的文件名列表。依赖可以为空,如”clean“,”clean“只有命令,没有依赖。
- command 也就是 make 需要执行的命令。(命令可以是任何一个shell可以执行的命令。)
- 那个标的 (target) 就是我们想要创建的信息,而目标文件就是具有相关性的 object files ,那创建可执行文件的语法就是以 <tab> 按键开头的那一行!特别给他留意喔,“命令列必须要以 tab 按键作为开头”才行!他的规则基本上是这样的:
- 在 makefile 当中的 # 代表注解;
- <tab> 需要在命令行 (例如 gcc 这个编译器指令) 的第一个字符;
- 标的 (target) 与相依文件(就是目标文件)之间需以“:”隔开
3.2 Makefile简单操作
- 我们来创建一个Makefile文件来对它进行学习(makefile也可以,大小写无影响)
- 我们现在需要用gcc调用下面的代码才可以编译test.c,但是现在我们将代码写入Makefile
mytest:test.c
gcc -o mytest test.c
- 现在我们返回命令行,输入make命令,看看会发生什么
3.3 原理(依赖关系和依赖方法)
- 对于
mytest:test.c
,冒号左侧是目标文件,右侧是它的依赖文件,所以就可以说它们之间存在一种【依赖关系】,只有test.c存在才可以有mytest
3.4 深层理解
通过上面,我们已经基本理解make中指令其实就是调用Makefile中的方法,那么方法的调用是什么逻辑呢?
1 mytest:test.o
2 gcc test.o -o mytest
- 因为可执行文件mytest是依赖于汇编后的目标文件test.o的,但是现在我们没有这个文件,因此就要去倒推一下如何获取这个test.o
- 对于test.o来说,它依赖于test.s这个经过编译之后文件,可是【test.s】不存在,所以跳转到下一条依赖关系
3 test.o:test.s
4 gcc -c test.s -o test.o
- 对于
test.s
来说,它依赖于test.i
这个经过预编译之后的文件,可是【test.i】不存在,所以跳转到下一条依赖关系
5 test.s:test.i
6 gcc -S test.i -o test.s
对于test.i
来说,它依赖于test.c
这个源文件,查找后发现源文件存在,于是开始执行gcc命令
7 test.i:test.c
8 gcc -E test.c -o test.i
4、总结汇总
这里我们只对make与Makefile进行简单了解,并不进行过多的解释和学习,因为make与Makefile需要后续的不断学习才能更好的理解,这篇文章仅仅作为简单介绍和说明即可,所以这篇文章我们只知道它即可!
结语
make与Makefile后续我会不断学习,直到达到可以完整讲述他们的用法后再给大家细讲,这篇文章质量并不高,希望大家谅解。