make/Makefile
参考文章:爱编程的大丙
1.什么是make /makefile?为什么要使用?
make是一个命令工具,是一个解释makefile中指令的命令工具。
makefile是一个文件,关系到了整个工程的编译规则。
使用 GCC 的命令行进行程序编译在单个文件下是比较方便的,当工程中的文件逐渐增多,甚至变得十分庞大的时候,使用 GCC 命令编译就会变得力不从心。
这种情况下我们需要借助项目构造工具 make 帮助我们完成这个艰巨的任务。一般来说,大多数的IDE都有这个命令,比如:Visual C++的nmake,QtCreator的qmake等。
make工具在构造项目的时候需要加载一个叫做makefile的文件,makefile关系到了整个工程的编译规则。一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。
makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。
2.如何使用make/makefile
makefile文件有两种命名方式 makefile 和 Makefile, 构建项目的时候在哪个目录下执行构建命令 make这个目录下的 makefile 文件就会别加载,因此在一个项目中可以有多个 makefile 文件,分别位于不同的项目目录中。
(1)makefile基础框架
1. 规则
Makefile的框架是由规则构成的。make命令执行时先在Makefile文件中查找各种规则,对各种规则进行解析后运行规则。规则的基本格式为:
#目标文件【:】依赖文件 # 构成有依赖关系
target1,target2...: depend1, depend2, ...
【Tab缩进】command # 依赖方法
...
每条规则由三个部分组成分别是目标(target), 依赖(depend)和命令(command)。
命令(command):
- 当前这条规则的动作,一般情况下这个动作就是一个 shell 命令
- 例如:通过某个命令编译文件、生成库文件、进入目录等。
- 动作可以是多个,每个命令前必须有一个Tab缩进并且独占占一行。
gcc -o mybin test.c #编译test.c,形成mybin的可执行文件
依赖(depend):
- 规则所必需的依赖条件,在规则的命令中可以使用这些依赖。
- 例如:生成可执行文件的目标文件(*.o)可以作为依赖使用
- 如果规则的命令中不需要任何依赖,那么规则的依赖可以为空
- 当前规则中的依赖可以是其他规则中的某个目标,这样就形成了规则之间的嵌套
- 依赖可以根据要执行的命令的实际需求, 指定很多个
目标(target):