一个工程中的源文件不计其数,其按照类型、功能、模块分别放在若干个目录中,Makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重编译,甚至进行更复杂的功能操作。
Makefile文件主要包括五方面内容:
显示规则、隐晦规则、变量定义、文件指示、注释
功能:
关系到整个工程的编译规则,也可执行操作系统的命令
好处:实现“自动化编译”,一旦写好,只需要输入一个make命令,整个工程就会完全自动编译,极大了提高了编译效率(只会依赖修改的和依赖于修改的那些文件)
Make命令: make命令就是一个命令工具,是一个解释Makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,visual C++中的 nmake,linux下GNU的make。
- 简单的编写步骤:
比如说现在有五个文件:main.c my1.h my2.h my1.c my2.c
现在编写Makefile文件,名为Makefile的过程如下:
main : main.o my1.o my2.o
gcc -o main main.o my1.o my2.o
main: mian.c my1.h my2.h
gcc -c main.c
my1.o: my1.c my1.h
gcc -c my1.c
my2.o: my2.c my2.h
gcc -c my2.c
clean:
rm -f *.o main
执行命令: make 就可以生产可执行文件main,如果想删除可执行文件以及所有的中间目标文件,只需要执行下 make clean
**clean 不是一个文件,它只是一个动作的名字,如C中的 lable, 冒号后什么都不做。
2.文件说明
makfile文件中,目标文件包括:执行文件make 、 中间目标文件 (.o)文件、依赖文件(冒号后面的那些文件),每一个.o文件后面都有一组依赖文件,而这些.o文件又是执行文件main的依赖条件。依赖关系的实质上就是说明了目标文件是由那些文件生成的。
依赖: 即目标问价由哪些文件生成。如果说依赖条件中存在不存在的依赖条件,则会寻找其他规则是否可以产生依赖条件。
例如: 规则一是 生成目标文件 hello.out 需要用到依赖条件hello.o ,但是hello.o 不存在,则Makefile会寻找到一个 生成 hello.o的规则二并执行。
命令: 通过执行该命令,由依赖文件生成目标文件。注意每一条命令前必须有且仅由一个tab 保持缩进,这是语法要求。
ALL: Makefile文件默认只生成第一个目标文件即完成编译,但是我们可以通过ALL 指定需要生成的目标文件。
3.Make的工作原理
Make是解释Makefile中指令的命令工具
当我们输入make时:
- make首先会在当前目录下找到相关Makefile文件;
- 如果找到,她会找到这个文件中的第一个目标文件main,并把这个文件作为最终的目标文件。
- 如果说mainwe文件不存在或者说main文件后面依赖的.o文件不存在的话,那么就会执行后续的定义的命令来生成main这个文件。
- 如果说这个.o文件也存在,那么make就会在当前文件中查找.o文件的依赖性,如果找到,则再根据那一个原则生成.o文件。
- 由于我的c文件和h文件是存在的,所以make会生成.o文件,然后再用.o文件声明make的最终文件,也就是执行文件make。
4.make和Makefile的联系
Make是一个命令,Makefile是一个文件,当Makefile文件写好之后,只需要一个make命令就可以把Makefile文件运行起来。