makefile的入门学习

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。

你可能感兴趣的:(makefile的入门学习)