makefile命令基本运用

Posted BlackMamba24

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了makefile命令基本运用相关的知识,希望对你有一定的参考价值。

   一、makefile介绍:

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

    Linux 环境下的程序员如果不会使用GNU make来构建和管理自己的工程,应该不能算是一个合格的专业程序员。在 Linux(unix )环境下使用GNU 的make工具能够比较

容易的构建一个属于你自己的工程,整个工程的编译只需要一个命令就可以完成编译、连接以至于最后的执行。不过这需要我们投入一些时间去完成一个或者多个称之为

Makefile 文件的编写。

    所要完成的Makefile 文件描述了整个工程的编译、连接等规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。尽管看起

来可能是很复杂的事情,但是为工程编写Makefile 的好处是能够使用一行命令来完成“自动化编译”,一旦提供一个正确的Makefile。编译整个工程你所要做的唯一的一件事就是在shell 提示符下输入make命令。

整个工程完全自动编译,极大提高了效率。

   二、makefile使用

        因为刚刚了解makefile,就简单的实现一个创建动态函数库和静态函数库的功能

        

 

三、makefile规则

   #第一条目标为总的目标,

  #依赖可以是文件(目录)或为其他目标

  #动作可以是Linux命令,动作的那一行第一个字符必须是以TAB键
  target: depend1 depend2 depend3 ...
  [TAB] action1
  [TAB ] action2
  target1:
 [TAB] action1
 [TAB] action2

四、make的使用

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

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

  make -C directory 进入到directory文件夹中去执行总的目标

  make clean -c direcotry 进入到directory文件夹中去执行clean目标

  make -f comm_makefile 通过-f选项指定一个makefile文件

  make VAR=value 给Makefile传一个参数VAR,其值为value

 

以上是关于makefile命令基本运用的主要内容,如果未能解决你的问题,请参考以下文章

makefile

make的使用和Makefile规则和编程及其基本命令(简单)

Makefile文件的基本单元 —— 规则

Linux下Makefile

makefile 使用介绍

Linux虚拟机下makefile的编写应用