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

举报
糖果罐子 发表于 2023/07/21 19:55:55 2023/07/21
【摘要】 从这篇文章开始就开始进入 Makefile 的***零基础教程***,相信只要看了本教程的都可以对 Makefile 有一个清晰的理解和正确的运用。那么现在就开始我们的 Makefile 学习之路。@TOC 一、什么是 Makefile,优点?Makefile 简介:Makefile 是一种用于自动化构建程序的脚本文件,通常包含了一系列规则和命令,用于指导构建系统如何生成目标文件。在构建程序...

从这篇文章开始就开始进入 Makefile 的***零基础教程***,相信只要看了本教程的都可以对 Makefile 有一个清晰的理解和正确的运用。那么现在就开始我们的 Makefile 学习之路。

@TOC


一、什么是 Makefile,优点?

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

  2. Makefile 是一个描述文件。

  • 定义一系列规则来指定源文件编译的先后顺序。
  • 拥有特定的语法规则,支持函数定义 和 函数调用。
  • 能够直接集成操作系统中的各种命令。
  1. Makefile 的优点:
    包括其灵活性和高效性。一旦生成了Makefile,只需要简单地调用make命令,系统就能自动根据Makefile中的规则和命令,执行构建过程。这大大简化了构建过程,提高了构建效率。

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

  1. make 可以根据 Makefile 文件的规则和依赖关系,自动判断哪些文件需要重新构建,并调用相应的编译器、链接器等工具完成构建过程。make可以大大简化程序的构建工作,提高开发效率和代码质量。在使用make时,需要先编写 Makefile 文件,指定编译规则、依赖关系和命令等信息,然后执行make命令即可自动构建程序。

  2. make 是一个应用程序

  • 解析源程序之间的依赖关系。
  • 根据依赖关系==自动维护==编译工作。
  • 执行宿主操作系统中的各种命令。
  1. 在工程中,我们面对的代码是成千上万的,如果使用 gcc- 编译器,我们会在后面写一大堆东西吗?
    答案是当然不会。make实现了增量编译的机制,只编译需要更新的文件,避免了不必要的重复编译,节省了时间和计算资源。同时,make支持多线程编译,可以提高编译速度,加快产品上线的速度。

三、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 的结构。

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。