makefile学习笔记

参考:

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隔开的文件列表(这些文件用于创建目标文件);


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值