Linux环境编程--Makefile的使用

一.使用目的

    一个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为 makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。

   在 Linux(unix )环境下使用GNU 的make工具能够比较容易的构建一个属于你自己的工程,整个工程的编译只需要一个命令就可以完成编译、连接以至于最后的执行。不过这需要我们投入一些时间去完成一个或者多个称之为Makefile 文件的编写。

    Makefile 文件描述了整个工程的编译、连接等规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。尽管看起来可能是很复杂的事情,但是为工程编写Makefile 的好处是能够使用一行命令来完成“自动化编译”,一旦提供一个正确的 Makefile。编译整个工程你所要做的唯一的一件事就是在shell 提示符下输入make命令。整个工程完全自动编译,极大提高了效率。

二.Makefile的结构

     # .. #表示注释

    #变量定义

    VAR=test 定义变量VAR强制赋值为app

    VAR+=app 在VAR之前定义的值后面追加app这个值

    VAR?=testapp 如果之前VAR没被定义,则定义并使用testapp否则使用之前的值

 

    #第一条目标位总的目标

    #一来可以是文件(目录)或为其他目标

    #动作可以是Linux命令,动作的第一行必须是以TAB键

    1.大体规则

    target: depend1 depengd2 depend3 ..    //必须执行(主要目标)

    [TAB] action1

    [TAB] action2

    target1:        //次要(需要通过命令操作系统make target1执行)

    [TAB] action1

    [TAB] action2

    target2:        //次要

    ...

    target3:         //次要

   ...

     2.在前头定义的变量xxx可以在后头用${xxx}调用

    3.前缀@可以隐藏动作语句(如果不隐藏该语句,则在操作系统下调用make时,执行动作语句会被显示出来)

编写完makefile之后在操作系统输入的指令命令解释:

    4.make 找makefile或Makefile文件执行总目标

    5.make clean 执行makefile文件中的clean目标

    6.make -C directory 进入到directory文件夹中去执行总的目标(如果编写的makefile有这个功能)

三.makefile的应用举例

例如:最简单的makefile规则

Linux环境编程--Makefile的使用

作用:主目标是将main.c和test.c一起编译并且叫做link(调用命令make即可)

    清除这个link(调用命令make clean即可)

例如:制订简单的动态库和静态库v1.0

Linux环境编程--Makefile的使用

作用:分别制作出简单的静态库,动态库,并且清楚多余的.o文件(编译之间转换多余的文件),次要目标清除app
    该程序运行结果:

Linux环境编程--Makefile的使用