Makefile零基础教学(一)初识makefile

简介: Makefile零基础教学(一)初识makefile

一、什么是 Makefile,优点?

1.Makefile简介:
Makefile 是一种用于自动化构建程序的脚本文件,通常包含了一系列规则和命令,用于指导构建系统如何生成目标文件。在构建程序时,Makefile 会根据文件之间的依赖关系,自动决定哪些文件需要重新构建,以及如何进行构建。

2.Makefile是一个描述文件。

  • 定义一系列规则来指定源文件编译的先后顺序。
  • 拥有特定的语法规则,支持函数定义 和 函数调用。
  • 能够直接集成操作系统中的各种命令。

3.Makefile 的优点:
包括其灵活性和高效性。一旦生成了Makefile,只需要简单地调用make命令,系统就能自动根据Makefile中的规则和命令,执行构建过程。这大大简化了构建过程,提高了构建效率。image.png

二、什么是 make, 为什么使用make?

  1. make 可以根据 Makefile 文件的规则和依赖关系,自动判断哪些文件需要重新构建,并调用相应的编译器、链接器等工具完成构建过程。make可以大大简化程序的构建工作,提高开发效率和代码质量。在使用make时,需要先编写 Makefile 文件,指定编译规则、依赖关系和命令等信息,然后执行make命令即可自动构建程序。
  1. make是一个应用程序
  • 解析源程序之间的依赖关系
  • 根据依赖关系自动维护编译工作。
  • 执行宿主操作系统中的各种命令。
  1. 在工程中,我们面对的代码是成千上万的,如果使用 gcc- 编译器,我们会在后面写一大堆东西吗?

答案是当然不会。make实现了增量编译的机制,只编译需要更新的文件,避免了不必要的重复编译,节省了时间和计算资源。同时,make支持多线程编

  1. 译,可以提高编译速度,加快产品上线的速度。

三、make 和 Makefile 的关系

makemakefile 是紧密相关的两个概念。 make 可以根据 Makefile 文件的规则和依赖关系,自动判断哪些文件需要重新构建,并调用相应的编译器、链接器等工具完成构建过程。

Makefile 中的描述用于指导 make 程序如何完成工作; make 根据 Makefile 中的规则执行命令,最后完成编译输出

因此,可以说make依赖于Makefile,而Makefile则是make的输入文件。

通常,程序员会自己编写Makefile文件,以指导make执行正确的构建过程。Makefile文件可以由文本编辑器或专业的集成开发环境(IDE)创建和编辑,然后保存到项目的根目录或指定的目录中。

四、简单的 Makefile 示例:


首先,让大家观赏一下 最简单的 Makefile 示例是什么样子滴。

1. 最简单的 Makefile 示例

hello:
  echo "hello makefile"

可能有的童鞋看到这个会很蒙,不知道这是什么鬼东西。

那么现在给大家讲解一下,请看下图:

这个代码片段是一个最简单的Makefile文件,包含了一个规则和一条命令,其中:

(1) . 规则 :

hello:

这一部分定义了一个 名为"hello"的规则,用于指导make如何生成一个名为"hello"的目标文件 或执行一组相关的命令。这个规则没有依赖(关于依赖,我们下一篇文章会详细讲解,这里大家先看看),表示无论何时执行make都会执行这个规则。

(2) . 命令 :

echo "hello makefile"

这一部分是一个简单的Shell命令,用于输出一个字符串"hello makefile"。当make执行到"hello"这个规则时,它会运行这个命令,并输出相应的结果

注意: 目标后的命令需要用 Tab 键 ( ' \t ' ) 隔开!!!

echo是一个常见的命令行命令,它的作用是输出一段文本内容到终端(或标准输出)综上所述,当运行make hello 命令时,make程序会读取这个Makefile文件,并执行其中的规则和命令。在这个例子中,它会输出"hello makefile"这个字符串到终端上。

2. make 程序的使用示例

make  -f  mf.txt  hello

功能说明:

以 hello 关键字作为目标查找 mf.txt 文件,并执行 hello 处的命令

  • -f 参数指定要使用的 Makefile 文件名。在本例中,使用的文件名为 mf.txt。
  • hello 是一个目标名称,表示执行的目标是名为 hello 的规则。在本例中,Makefile 文件 mf.txt 中应该包含定义名为 hello 的规则的指令。

这个命令行指令的作用是使用 Makefile 文件 mf.txt 中的规则和命令来生成或更新名为 hello 的目标文件。如果 Makefile 文件中没有定义名为 hello 的规则,则命令行指令将无法完成执行。

3. make 程序的简写

  1. 以 hello 关键字作为目标 查找 makefile 或 Makefile 文件,并执行 hello 处的命令。
make  hello

例如:下面的一个 makefile 文件,里面有 2 条命令,分别是 hello 和 text 。如果我们执行 make hello ,则会 执行哪条命令呢?

答案当然是 hello 后的命令了,因为 我们 的 make 后跟着的是 hello 目标。这里不是因为 hello 对象在最上面。

结果是 在终端打印处 hello makefile 字符串。

  1. 查找 makefile 或 Makefile 文件中的最顶层目标,并执行最顶层目标的命令。
make

提问: 对于上面同一个 makefile 文件,我们这次执行 make ,那么会执行哪条命令呢?

答案: 执行 第一条 hello 目标后的命令。 因为 我们这里 只 查找 makefile文件中的最顶层目标(最顶层当然就是第一条 hello 了),并执行最顶层目标的命令。

结果是 在终端打印处 test 字符串。


总结

相信大家 已经对 Makefile 有了一个大致的了解了,那么下一节将为大家 详细介绍 Makefile 的结构。

相关文章
|
8月前
|
编译器 Shell Linux
Makefile(3)进阶
Makefile(3)进阶
59 0
|
C语言
Makefile教程(Makefile的结构)
Makefile教程(Makefile的结构)
120 0
|
vr&ar
Makefile基础教学(预定义变量)
Makefile基础教学(预定义变量)
144 0
|
5月前
|
编译器 C语言
针对make工具和Makefile文件的学习心得
【8月更文挑战第24天】本文分享了关于 make 工具和 Makefile 文件的学习心得。make 工具与 Makefile 在软件开发特别是大型项目中扮演着重要角色,能自动化构建流程并提升开发效率。文章首先强调了了解 make 和 Makefile 重要性的必要性,并详细解析了 Makefile 的基本结构:包括目标、依赖和命令的定义;通过变量简化命令与依赖;以及伪目标的使用等。接着,文中介绍了几个关键的 Makefile 编写技巧:如何合理组织依赖关系,有效利用变量和宏,灵活运用自动变量,以及添加清晰的注释等。
|
5月前
|
编译器 Linux C语言
Makefile实战论(一)
Makefile实战论(一)
|
8月前
Makefile(1)入门
Makefile(1)入门
57 0
|
编译器 Shell Linux
Makefile学习1
Makefile学习1
|
IDE Linux Shell
【Makefile】简单的Makefile编写
【Makefile】简单的Makefile编写
|
Java Linux 程序员
玩转Makefile | 一文入门Makefile
玩转Makefile | 一文入门Makefile
250 0
玩转Makefile | 一文入门Makefile

热门文章

最新文章