1. makefile作用:
正常一个main函数通过编译链接可以生成可执行程序,例如:
cc -c main.c #生成main.o文件 cc -o main main.o #生成main可执行文件
但是当一个大工程有大量源代码文件和头文件时,就需要多条命令才能完整编译链接。makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,就像一个Shell脚本一样。然后执行make命令即可执行。
主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释
2. makefile简单示例
2.1 基本格式
target ... : prerequisites ...
command
target :目标文件, 可以是 Object File, 也可以是可执行文件
prerequisites :生成 target 所需要的文件或者目标
command : make需要执行的命令 (任意的shell命令), Makefile中的命令必须以 [tab] 开头
2.2 简单样例
edit :main.o tool.o
cc -o edit main.o tool.o #如果长度太长,可以用 \ 换行编写,方便阅读
main.o : hwl.h main.c
cc -c main.c
tool.o : hwl.h tool.c
cc -c tool.c
clean :
rm -rf edit main.o tool.o #注释...反斜杠转义 \#
上面的示例说明了edit文件依赖main.o和tool.o,main.o依赖hwl.h和main.c。这同时说明了当main.c更新了,main.o需要重新执行生成,edit也进而需要重新生成。
clean是一个动作名字,像lable一样,其冒号后什么也没有,那么make就不会去找文件的依赖性,也就不会自动执行其后所定义的命令。执行其后的命令要在make命令后指出这个lable的名字(比如 make clean)。
2.3 简化
● 例子中比如.o文件重复写了多次,可以定义变量来替代,使用时通过$(var)调用
● GNU的make很强大,它可以自动推导文件以及文件依赖关系后面的命令。make看到一个[.o]文件,它就会自动的把[.c]文件加在依赖关系中,如果make找到一个main.o,那么main.c,就会是main.o的依赖文件。并且 cc -c main.c 也会被推导出来,makefile也不用写得这么复杂。
OBJ=main.o tool.o
edit :$(OBJ)
cc -o edit main.o tool.o
main.o : hwl.h
tool.o : hwl.h
clean :
rm -rf edit $(OBJ)
3. make工作原理
● make会在当前目录下找名字”GNUmakefile“、“Makefile”或“makefile”的文件。
建议使用Makefile,最好不要用“GNUmakefile”,这个文件是GNU的make识别的。如果用其他的名字,就需要make命令显示指定文件名。make -f 或make --file。
● 如果找到,它会找文件中的第一个目标文件(target),并把这个文件作为最终的目标文件。
● 如果edit文件不存在,或是edit所依赖的后面的 .o 文件的文件修改时间要比edit这个文件新,那么,他就会执行后面所定义的命令来生成edit这个文件。
● 如果edit所依赖的.o文件也不存在,那么make会在当前文件中找目标为.o文件的依赖性,如果找到则再根据那一个规则生成.o文件。
● make会生成 .o 文件,然后再用 .o 文件生成执行文件edit。