您的位置:首页 > 运维架构 > Linux

我们一起在linux下学习使用makefile

2013-11-24 19:46 507 查看
makefile可以在很大程度上简化编译链接的复杂度和工作量,使用普遍。我们就makefile的特点/使用进行学习。

(1)有四个原始码档案

(可以到 http://linux.vbird.org/linux_basic/0520source/main.tgz

进行下载),在shell下对多个原始码文件进行编译时,需要分别对这些原始码进行编译:



当有大量原始文件时,看起来就非常复杂,而且修改某些原始码文件之后再进行编译时,工作量和首次相同,对cpu的占有量也比较大。
与此相比,使用makefile有以下特点:
1)如果这个工程没有编译过,那么我们的所有C文件都要编译并被链接。 

2)如果这个工程的某几个C文件被修改,那么我们只编译被修改的C文件,并链接目标程。 

3)如果这个工程的头文件被改变了,那么我们需要编译引用了这几个头文件的C文件,并链接目标程序。   

只要我们的Makefile写得够好,所有的这一切,我们只用一个make命令就可以完成,make命令会自动智能地根据当前的文件修改的情况来确定哪些文件需要重编译,从而自己编译所需要的文件和链接目标程序。

(2)我们先通过对上面例子的编译过程,对makefile的使用进行说明,然后再对其规则进行说明概括。

首先,用vim创建一个makefile文件(在linux下,makefile默认使用makefile作为makefile,可以使用make时指定-f选项进行修改)



然后对makefile文件进行最基本地编写



然后在shell下面,我们就可以通过make main来进行编译链接,通过make clean来清除目标文件和可执行文件了。

运行./main,结果如下:



根据上例,我们对makefile的语法规则进行一下如下:

Targets:Prerequisites

Command

说明:

    Targets(目标):文件名,以空格分开,可以使用通配符,通常是一个文件,也可以是多个文件;

    Prerequisites(依赖目标):生成Targets所需要的文件或是目标;

    Command(命令行):命令行,make所需要执行的命令,如果和Prerequisites在一行,可以用分号分隔,与在一行的时候,必须要以<Tab>键开头,和shell环境一样,Command命令太长时,可以使用反斜框(\)作为换行。

     实际上就是通过Targets和Prerequisites来确定依赖关系,依赖关系的实质上就是说明了目标文件是由哪些文件生成的。在定义好依赖关系后,后续的那一行定义了如何生成目标文件的操作系统命令,一定要以一个Tab键作为开头。

     这里要说明一点的是,clean不是一个文件,它只不过是一个动作名字,有点像C语言中的lable一样,其冒号后什么也没哟,就不会自动执行其后所定义的命令。要执行其后的命令,就要在make命令后明显得指出这个lable的名字。在这个例题中,make和make main执行的结果是一样的,但要执行clean,就要使用make clean。这样的方法非常有用,我们可以在一个makefile中定义不用的编译或是和编译无关的命令,比如程序的打包/备份等。

(3)变量的使用



从上面makefile文件中可以看到每个*.o文件出现了三次,当makefile十分复杂的时候,就会很容易出现错误,导致编译通不过。为了简化makefile文件的编写,引入了变量的概念,它和C语言中的宏很相似。
      变量在使用时会在前面加个 $,一般还会加上()或{ }包括起来,不要使用关键字,一般用大写区分。
      引入变量之后,我们上面例题的makefile文件变为:

     


      变量使得makefile看起来简练了许多,而且物理含义明显。

Shift+PrScrn:截图
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: