makefile学习之路——makefile简介

Posted

tags:

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

一、make简介

make是一个指令工具,它解释makefile中的指令或者说规则。makefile文件描述了整个工程中所有文件的**编译顺序,编译规则**。Makefile也有自己的编写规则,通常,我们所使用的IDE都会生成相应的makefile,然后再根据makefile来进行编译,只是这些操作是由IDE来完成,我们只需要点击一个编译按钮。

二、为什么要使用make

现在可以在GitHub上看到,很多的开源项目,在编译的时候,都是使用make来完成的,也就是说,都有其对应的makefile。他们都有个特点,那就是文件很多。

考虑这样一种情况,我们的项目现在有三、四十个文件,你使用的不是IDE工具,而是命令行,那么不同的人,在编译你的项目的时候,都需要一个一个文件的

gcc -o asample.c bsample.c ...... xxx.out

,这样慢慢的一个文件,一个文件的去找到以后再编译吗?

答案肯定是否定的,当你工程的文件多了以后,时间一长,可能你自己都不能记住所有的文件。所以,这个时候我们就可以使用make来根据makefile对整个项目进行管理。除此之外,make还有一个优点,那就是当你修改你的文件以后,make只会编译更新的文件以及它相关依赖的文件。这里后边进行详细的解释,意思就是,当你只修改了几十个文件中的某一个文件时,make只会重新编译跟你修改的文件有关联的文件,而不是所有的文件。这就大大的减短了编译的时间。



三、makefile简介

在我们执行make之前,需要有一个名为makefile或Makefile的文件。这个文件用来告诉make需要完成什么样的操作。我们可以简单的把makefile认为是一份定义了源文件间依赖关系、如何编译各个源文件并生成可执行文件的说明书。


四、makefile的基本结构

TARGET... : PREREQUISITES...
    COMMAND
    ...
    ...

TARGET:规则的目标,最终生成文件的名字或者是中间过程文件名,也可以是make执行的动作的名称。

PREREQUISITES:规则的依赖,生成目标所必须的文件名列表。

COMMAND:规则的命令。规则需要执行的动作

        注意:这里需要注意的是,命令前面使用的是TAB键,而不是空格,使用空格会出现错误。



五、第一个makefile

        makefile文件内容如下

hello : 
    echo "hello makefile"
test : 
    echo "test"
    pwd
    ls


执行结果如图所示

技术分享图片

        从图中可以看到,我们执行make时,打印了echo "hello makefile"hello makefile两句话。使用make hello的结果跟make相同,而使用make test,的打印结果,则与前面两者不同。

        为什么会是这样呢?

        因为make在执行时,如果没有参数,那么就会首先执行第一个规则,而make hellomake test则是执行对应目标下的规则,所有,虽然makemake hello的结果是相同的,但是实际上,两者的意义还是有区别的。






以上是关于makefile学习之路——makefile简介的主要内容,如果未能解决你的问题,请参考以下文章

makefile学习之路——变量

Makefile学习之路5——通过函数增强功能

Makefile学习之路——4

makefile学习之路——函数调用

makefile学习之路——变量和函数调用小结

CMake学习之路