美文网首页
makefile的入门学习

makefile的入门学习

作者: 夏至悲歌 | 来源:发表于2018-10-03 23:11 被阅读0次

1. makefile作用:

        正常一个main函数通过编译链接可以生成可执行程序,例如:

        cc -c  main.c   #生成main.o文件     cc -o main main.o  #生成main可执行文件

        但是当一个大工程有大量源代码文件和头文件时,就需要多条命令才能完整编译链接。makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,就像一个Shell脚本一样。然后执行make命令即可执行。

        主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释

2. makefile简单示例

2.1 基本格式

target ... : prerequisites ...

        command

target             :目标文件, 可以是 Object File, 也可以是可执行文件

prerequisites :生成 target 所需要的文件或者目标

command      : make需要执行的命令 (任意的shell命令), Makefile中的命令必须以 [tab] 开头

2.2 简单样例

edit :main.o tool.o

        cc -o edit main.o tool.o               #如果长度太长,可以用 \ 换行编写,方便阅读

main.o : hwl.h main.c

        cc -c main.c

tool.o : hwl.h tool.c

        cc -c tool.c

clean :

        rm -rf edit main.o tool.o       #注释...反斜杠转义  \#

        上面的示例说明了edit文件依赖main.o和tool.o,main.o依赖hwl.h和main.c。这同时说明了当main.c更新了,main.o需要重新执行生成,edit也进而需要重新生成。

        clean是一个动作名字,像lable一样,其冒号后什么也没有,那么make就不会去找文件的依赖性,也就不会自动执行其后所定义的命令。执行其后的命令要在make命令后指出这个lable的名字(比如 make clean)。

2.3 简化

●  例子中比如.o文件重复写了多次,可以定义变量来替代,使用时通过$(var)调用

●  GNU的make很强大,它可以自动推导文件以及文件依赖关系后面的命令。make看到一个[.o]文件,它就会自动的把[.c]文件加在依赖关系中,如果make找到一个main.o,那么main.c,就会是main.o的依赖文件。并且 cc -c main.c 也会被推导出来,makefile也不用写得这么复杂。

OBJ=main.o tool.o

edit :$(OBJ)

cc -o edit main.o tool.o              

main.o : hwl.h

tool.o : hwl.h

clean :

        rm -rf edit $(OBJ)


3. make工作原理

●   make会在当前目录下找名字”GNUmakefile“、“Makefile”或“makefile”的文件。

        建议使用Makefile,最好不要用“GNUmakefile”,这个文件是GNU的make识别的。如果用其他的名字,就需要make命令显示指定文件名。make -f 或make --file。

●  如果找到,它会找文件中的第一个目标文件(target),并把这个文件作为最终的目标文件。

●  如果edit文件不存在,或是edit所依赖的后面的 .o 文件的文件修改时间要比edit这个文件新,那么,他就会执行后面所定义的命令来生成edit这个文件。

●  如果edit所依赖的.o文件也不存在,那么make会在当前文件中找目标为.o文件的依赖性,如果找到则再根据那一个规则生成.o文件。

●  make会生成 .o 文件,然后再用 .o 文件生成执行文件edit。

相关文章

  • makefile的入门学习

    1. makefile作用: 正常一个main函数通过编译链接可以生成可执行程序,例如: cc -...

  • Makefile学习笔记

    Makefile学习笔记 学习Makefile的资料 《跟我一起写makefile》 《GUN make manu...

  • Makefile入门

    0. 作用 Makefile文件告诉Make怎样编译和连接成一个程序。 1. Makefile基本语法与执行 示例...

  • Makefile入门

    make是由一组一组的规则组成的 规则的书写形式: 目标:依赖 [tab]命令 makefile变量 变量名 = ...

  • Makefile入门

    make是一个自动化构建工具,广泛应用于Unix及其类Unix系统中。make最先应用于编译C语言项目,不仅如此,...

  • makefile入门

    典型的makefile规则如下,参考howto_makefiles target 通常是程序所生成的文件的名字,类...

  • Makefile入门(二):MakeFile介绍

    makefile 介绍 make命令执行时,需要一个 makefile 文件,以告诉make命令如何去编译和链接程...

  • Makefile自动化变量

    学习笔记,摘自陈皓的《跟我一起写 Makefile》 Makefile规则 Makefile文件由一系列规则构成。...

  • Makefile学习

    Makefile学习 参考自《跟我一起写Makefile》陈皓 Makefile 的语法规则 基本语法 翻译成中文...

  • makefile快速入门

    makefile的作用:简化编译的过程,通过脚本来执行编译命令1、注释:‘#’开头:如: #这是一个注释 2、执行...

网友评论

      本文标题:makefile的入门学习

      本文链接:https://www.haomeiwen.com/subject/dwytaftx.html