参考:
1、《跟我一起写Makefile----陈皓》
2、《Linux程序设计》
3、网上资源
一、概述
1、make是一个命令工具,是一个解释makefile中指令的命令工具,本质是在文件依赖性上做文章。
2、编译过程:首先要把源文件编译成中间代码文件,在windows下就是.obj文件,在类UNIX下是.o文件,即Object File,这个动作叫做编译(compile);然后再把大量的Object File合成执行文件,这个动作叫做链接即link;
3、编译时,编译器需要的是语法的正确,函数与变量的声明的正确,对于链接来说,通常是你需要告诉编译器头文件的所在位置(头文件中应该只是声明,而定义应该放在C/C++文件中),只要所有的语法正确,编译器就可以编译出中间目标文件。
4、一般来说,每个源文件都应该对应于一个中间目标文件(.o文件或是OBJ文件);链接时,主要是链接函数和全局变量,所以我们可以使用这些中间目标文件(.o文件或OBJ文件)来链接我们的应用程序,链接器并不管函数所在的源文件,只管函数的中间目标文件,在大多数时候,由于源文件太多,编译生成的中间目标文件太多,而在链接时需要明显的指出中间目标文件名,这对于编译很不方便,所以,我们要给中间目标文件打个包,在Windows下这种包叫做“库文件”library file,即.lib文件,在类UNIX下,是Archive File,也就是.a文件。
5、总结:源文件首先会生成中间目标文件,再由中间目标文件生成可执行文件,在编译时,编译器只检测程序语法,和函数、变量是否会被声明。如果函数未被声明,编译会给出一个警告,但可以生成Object File,而在链接程序时,链接器会在所有的Object File中找寻函数的实现,如果找不到,那就会报链接错误码linker error,在VC下,这种错误一般是:Link 2001错误,意思是说,链接器未找到函数的实现,你需要指定函数的Object File。
二、Makefile介绍
1、make命令中最常用的3个选项
-k:它的作用是让make命令在发现错误时仍然继续,而不是在检测到第一个错误时就停止;作用是可以让你在一次操作中发现所有未编译成功的源文件。
-n:它的作用是让make命令输出将要执行的所有操作步骤,而不真正执行这些操作。
-f <filename>:它的作用是告诉make命令将哪个文件作为makefile文件,如果未使用这个选项,则make命令将首先在当前目录下查找名为makefile文件,如果该文件不存在,它就会查找名为Makefile的文件。
2、创建目标
(1) makefile文件由一组依赖关系和规则构成,每个依赖关系有一个目标和一组该目标所依赖的源文件构成;而规则描述了如何通过这些依赖关系创建目标;一般来说,目标文件可以是可执行文件、静态库、动态库。
(2)make命令会读取makefile文件的内容,它先要确定最终目标文件;
确定目标文件的规则是:默认是all目标;如果未指定all目标,则make命令将只创建它在文件makefile中找到的第一个目标;
注:
在makefile中最终目标文件只有一个,默认情况下就是all目标;
在makefile中可能会生成多个中间目标文件,all目标文件依赖于某些中间目标文件。
3、依赖关系
依赖关系定义了最终应用程序里的每个文件与源文件之间的关系。
依赖关系的规则是:先写目标的名称,然后紧跟着一个冒号,接着是空格或者制表符tab,最后使用空格或者制表符tab隔开的文件列表(这些文件用于创建目标文件);