Linux下GNU的Makefile详解

Makefile 的规则:目标文件名(可执行文件,最终目标文件):目标文件生成所需要依赖的所有文件(.o文件)

                             (tab键)通过依赖文件生成目标文件的命令(或者说规则)          

                             目标文件名(.o文件):目标文件生成所需依赖的所有文件(.c文件.h文件)

                             (tab键)通过所依赖文件生成目标文件的命令(或者说规则)

                              ......

                             .PHONY:clean                  

                             clean:

                             (tab键)-rm 目标文件名(可执行文件)  所有依赖文件名(.o文件)

说明:输入make

           1.make会在当前目录下找名字叫“Makefile”或“makefile”的文件。

           2.如果找到,它会找文件中的第一个目标文件,并把这个文件作为最终的目标文件

           3.如果最终目标文件不存在,或是最终目标文件所依赖的后面的 .o 文件的文件修改时间要比最终目标文件新,那么,他就

执行后面所定义的命令来生成这个文件。

           4.如果最终目标文件所依赖的.o文件也不存在,那么make会在当前文件中找目标为.o文件的依赖性,如果找到则再根据那

个规则生成.o文件

          5.每个Makefile中都应该写一个清空目标文件(.o和执行文件)的规则,这不仅便于重编,也很利于保持文件的清洁

.PHONY意思表示clean是一个“伪目标”。而在rm命令前面加了一个小减号的意思就是,也许某些文件出现问题,但不要管,继续

后面的事。当然,clean的规则不要放在文件的开头,不然,这就会变成make的默认目标,相信谁也不愿意这样。不成文的规

是——“clean从来都是放在文件的最后”。

Makefie的显式规则:显式规则说明了,如何生成一个或多的的目标文件。这是由Makefile的书写者明显指出,要生成的文件,文

件的依赖文件,生成的命令。

Makefie的隐晦规则:make具有自动推导的功能,它可以自动推导文件以及文件依赖关系后面的命令,比如make找到一个

whatever.o,那么whatever.c,就会是whatever.o的依赖文件。并且 cc -c whatever.c 也会被推导出来,这种方法,也就是make

的“隐晦规则”

Makefile变量的定义:在Makefile中我们要定义一系列的变量,变量一般都是字符串,这个有点你C语言中的宏,当Makefile被执

行时,其中的变量都会被扩展到相应的引用位置上。具体定义方法:变量名=依赖文件 ;比如需要定义一个变量表示1.o ,2.o,3.o

三个依赖文件,先起一个变量名比如object,然后定义:objects=1.o 2.o 3.o  引用变量这样引用:$(objects)

Makefile的文件指示: 其包括了三个部分,一个是在一个Makefile中引用另一个Makefile,就像C语言中的include一样;另一个

是指根据某些情况指定Makefile中的有效部分,就像C语言中的预编译#if一样;还有就是定义一个多行的命令。

Makefile 的注释:Makefile中只有行注释,和UNIX的Shell脚本一样,其注释是用“#”字符,这个就像C/C++中的“//”一样。如果你

要在你的Makefile中使用“#”字符,可以用反斜框进行转义,如:“\#”。最后,还值得一提的是,在Makefile中的命令,必须要以

[Tab]键开始。

Makefile 的文件名:默认的情况下,make命令会在当前目录下按顺序找寻文件名为“GNUmakefile”、“makefile”、“Makefile”的文

件,找到了解释这个文件。在这三个文件名中,最好使用“Makefile”这个文件名,因为,这个文件名第一个字符为大写,这样有一

种显目的感觉。最好不要用 “GNUmakefile”,这个文件是GNU的make识别的。有另外一些make只对全小写的“makefile”文件名敏

感,但是基本上来说,大多数的make都支持“makefile”和“Makefile”这两种默认文件名。当然,你可以使用别的文件名来书写

Makefile,比如:“Make.Linux”,“Make.Solaris”,“Make.AIX”等,如果要指定特定的Makefile,你可以使用make的“-f”和“--file”参

数,如:make -f Make.Linux或make --file Make.AIX。

          

猜你喜欢

转载自blog.csdn.net/li_Xing666/article/details/81545108