【Linux】从入门到精通:Make与Makefile完全指南
🏆本篇主题为:从入门到精通:Make与Makefile完全指南
🏆个人主页:CILMY23-CSDN博客
🏆系列专栏:C++ | C语言 | Linux | Python | 数据结构和算法 | 算法专题
🏆感谢观看,支持的可以给个一键三连,点赞收藏+评论。如果你觉得有帮助,还可以点点关注
文章目录
- 从入门到精通:Make与Makefile完全指南
- 1. 什么是Make/Makefile?
- 为什么需要Make?
- 2. 安装
- Centos安装
- 3. Makefile基础语法
- 基本结构
- 4. Makefile的特性
- 4.1 makefile的执行顺序
- 4.2 makefile无法生成可执行文件
- 如何强制重新编译?
- 4.3 makefile进行多文件编译
- 4.4 makefile的自动推导
- 4.5 makefile的变量
- 4.6 makefile省去中间过程
从入门到精通:Make与Makefile完全指南
1. 什么是Make/Makefile?
Make是一个自动化构建工具,主要用于管理源代码的编译和构建过程。它通过读取Makefile文件来执行构建任务,能够自动检测文件变化并仅编译必要内容,显著提升开发效率。
为什么需要Make?
-
自动化重复的编译命令
-
处理复杂的依赖关系
-
实现增量编译(仅编译修改过的文件)
-
标准化团队的构建流程
2. 安装
Centos安装
# CentOS/RHEL
sudo yum install make
3. Makefile基础语法
因为make是一个命令,而makefile是一个文件,所以我们需要在我们的当前目录下创建一个makefile文件。
基本结构
Makefile 规则的基本格式为:
makefile
目标(target): 依赖(dependencies)command
makefile主要分为三个部分
- 目标文件 (target):要生成的文件或操作名称(如 hello.exe 或 clean)。
- 依赖文件 (dependencies):生成目标所需的文件或条件(如 hello.c)。
- 依赖方法,命令 (command):生成目标的具体命令(以 Tab 开头,不能用空格)。
参考如下,这里的phony先忽略,我们先看前面的就行了。

根据上图我们可以解释一下这三个部分,首先hello.exe是我们的目标文件,冒号后跟着的是一个依赖文件列表,按照空格为分割符,可以有多个文件,也可以为空。
再接下来是依赖方法,一定要用tab符号开头,然后写指令。

然后我们可以用make命令运行这一部分

我们可以看到生成了目标文件hello.exe,执行的命令,也就是依赖方法,是我们的第二行。
那我们生成的时候总会有很多的临时文件,怎么办呢?
这时候makefile就提供了一个清理功能。

我们可以在makefile文件中编辑clean,实现这一功能。
我们在终端中输入 make clean 就可以很好的清理了。

4. Makefile的特性
4.1 makefile的执行顺序
我们利用make执行makefile的时候,默认是从上往下执行的,也就是会生成第一个目标文件。

make会根据我们的makefile自动执行编译/清理工作。
4.2 makefile无法生成可执行文件
实际上makefile有一个特性,是对于最新的可执行文件默认不生成,这实际上是为了提高效率,你可以看到你的报错如图所示:

make说hello.exe 是最新的日期。
那makefile是怎么知道我们需要重新生成了呢?
这就不得不提我们之前涉及的一个时间了:

Make 的工作原理是基于时间戳的依赖检查,Make 会对比目标文件(如 hello.exe)和依赖文件(如 hello.c)的修改时间:如果目标文件比依赖文件旧(或目标文件不存在),则执行命令重新生成。如果目标文件比依赖文件新,则跳过命令,提示 is up to date。
所以当我们第一次执行 make
gcc -o hello.exe hello.c
Make 检测到 hello.exe 不存在 或 hello.c 被修改过,触发编译命令,生成 hello.exe。
第二次执行 make
make: 'hello.exe' is up to date.
Make 发现 hello.exe 已存在,且它的修改时间晚于 hello.c 的修改时间,因此认为无需重新编译。
如何强制重新编译?
如果希望无视时间戳强制重新编译,可以使用.PHONY:

方法:
.PHONY:xxx
xxx对应的依赖方法总是要执行的,xxx对应的是目标文件,或者clean。
4.3 makefile进行多文件编译
如果总是要写每个文件那就很麻烦了,因为一个工程里可能有很多文件,所以makefile提供了一种方法直接进行多文件的编译。
hello.exe:hello.cgcc -o $@ $^
这里的@就对应我们的目标文件,^就对应我们的依赖文件列表,这样的话我们就可以进行多文件的编译。

makefile就会自动替代,$可以理解为自动取内容。
4.4 makefile的自动推导
我们用makefile重新进行这个程序的完全翻译过程就好做多了


我们发现makefile给我们都按照顺序推导完了,生成了对应的目标文件,并且最终文件也可以运行.
从这个过程中我们发现,makefile/make会自动根据文件中的依赖关系,进行自动推导,帮助我们执行所有相关的依赖方法。
因为我们没有hello.o的依赖文件的时候,是无法生成hello.exe可执行文件的,所以第二行的命令就无法执行,
1 hello.exe:hello.o2 gcc -o hello.exe hello.o
makefile就会去找对应的依赖
3 hello.o:hello.s
4 gcc -c hello.s -o hello.o
makefile也同样找不到,直到最后一段找到了,然后此刻就会生成对应的依赖,所以这里有一个依赖链:修改hello.c会触发后续所有目标的重建(hello.i → hello.s → hello.o → hello.exe)。这个过程就像入栈一样,第一个入栈,然后第二个入栈……,执行的时候就像递归一样,往回推导,这也就是我们的makefile会自动推导的情况。
如果makefile中的内容是乱序的,那makefile也会自动推导,也就是顺序不影响makefile执行。但是我们得把最重要的文件放前面,就比如下面这种情况:


4.5 makefile的变量
makefile不像C语言那样设计变量,它跟python一样,左边是变量名字,右边的变量的内容。
目标文件的变量:
1 bin=hello.exe
//bin = hello.exe
注意,中间不能用空格, 也就是我们这里的第二种写法是不允许的。
同样的,依赖文件我们也可以采用这种形式
2 src=test.c
这里的依赖文件中间可以用空格隔开。
那如何使用变量呢?我们得加上$()

4.6 makefile省去中间过程
如果我们不想看到中间过程,只需要在对应的命令前面加上@就可以了。

这样中间过程就很简略了

相关文章:
【Linux】从入门到精通:Make与Makefile完全指南
欢迎来到 CILMY23 的博客 🏆本篇主题为:从入门到精通:Make与Makefile完全指南 🏆个人主页:CILMY23-CSDN博客 🏆系列专栏:C | C语言 | Linux | Python | 数据结构和算法 | 算法专题 …...
leetcode0014 最长公共前缀 -easy
1 题目:最长公共前缀 编写一个函数来查找字符串数组中的最长公共前缀。 如果不存在公共前缀,返回空字符串 “”。 示例 1: 输入:strs [“flower”,“flow”,“flight”] 输出:“fl” 示例 2: 输入&a…...
【星云 Orbit-F4 开发板】07. 用判断数据尾来接收据的串口通用程序框架
【星云 Orbit-F4 开发板】用判断数据尾来接收一串数据的串口通用程序框架 摘要 本文介绍了一种基于STM32F407微控制器的串口数据接收通用程序框架。该框架通过判断数据尾来实现一串数据的完整接收,适用于需要可靠数据传输的应用场景。本文从零开始,详细…...
LLVM - 编译器前端 - 将源文件转换为抽象语法树(一)
一:概述 编译器通常分为两部分——前端和后端。在本文中,我们将实现编程语言的前端部分——即主要处理源语言的部分。我们将学习现实世界编译器使用的技术,并将其应用到我们的编程语言中。 本文将从定义编程语言的语法开始,最终生成一个抽象语法树(AST),这是代码生成的基…...
02_NLP文本预处理之文本张量表示法
文本张量表示法 概念 将文本使用张量进行表示,一般将词汇表示为向量,称为词向量,再由各个词向量按顺序组成矩阵形成文本表示 例如: ["人生", "该", "如何", "起头"]># 每个词对应矩阵中的一个向量 [[1.32, 4,32, 0,32, 5.2],[3…...
深圳SMT贴片加工核心工艺解析
内容概要 深圳作为全球电子制造产业的核心集聚区,其SMT贴片加工技术始终引领行业创新方向。本文聚焦深圳电子制造企业在高密度、微型化组件加工中的核心工艺体系,系统解析从锡膏印刷到成品检测的全流程关键技术。通过梳理SMT产线中设备参数设定、工艺条…...
P8720 [蓝桥杯 2020 省 B2] 平面切分--set、pair
P8720 [蓝桥杯 2020 省 B2] 平面切分--set、pair 题目 分析一、pair1.1pair与vector的区别1.2 两者使用场景两者组合使用 二、set2.1核心特点2.2set的基本操作2.3 set vs unordered_set示例:统计唯一单词数代码 题目 分析 大佬写的很明白,看这儿 我讲讲…...
突破传统:用Polars解锁ICU医疗数据分析新范式
一、ICU数据革命的临界点 在重症监护室(ICU),每秒都在产生关乎生死的关键数据:从持续监测的生命体征到高频更新的实验室指标,从呼吸机参数到血管活性药物剂量,现代ICU每天产生的数据量级已突破TB级别。传统…...
命名实体识别与文本生成算法
在自然语言处理(NLP)的浩瀚星空中,命名实体识别(Named Entity Recognition, NER)与文本生成算法如同两颗璀璨的星辰,各自闪耀,又相互辉映,共同推动着人工智能技术在语言理解与生成领…...
10.3 指针进阶_代码分析
代码分析 9. 指针和数组代码解析一维数组字符数组字符串二维数组 10. 指针代码分析eg1eg2eg3eg4eg5eg6eg7eg8 10.1 指针进阶_数组指针 10.2 指针进阶_函数指针 9. 指针和数组代码解析 数组名arr是首元素地址 例外: 1. sizeof(arr),计算整个数组的大小&…...
深入理解推理语言模型(RLM)
大语言模型从通用走向推理,万字长文解析推理语言模型,建议收藏后食用。 本文基于苏黎世联邦理工学院的论文《Reasoning Language Models: A Blueprint》进行整理,你将会了解到: 1、RLM的演进与基础:RLM融合LLM的知识广…...
在Nginx上配置并开启WebDAV服务的完整指南
在Nginx上配置并开启WebDAV服务的完整指南 如何在 Nginx 上开启 WebDAV 服务 要在 Nginx 上开启 WebDAV 服务,你需要配置 Nginx 以支持 WebDAV 请求。以下是详细的步骤: 1. 确保 Nginx 安装了 WebDAV 模块 Nginx 的 WebDAV 功能由 http_dav_module 模…...
大语言模型学习
大语言模型发展历程 当前国内外主流LLM模型 一、国外主流LLM LLaMA2 Meta推出的开源模型,参数规模涵盖70亿至700亿,支持代码生成和多领域任务适配57。衍生版本包括Code Llama(代码生成优化)和Llama Chat(对…...
夜天之书 #106 Apache 软件基金会如何投票选举?
近期若干开源组织进行换届选举。在此期间,拥有投票权的成员往往会热烈讨论,提名新成员候选人和治理团队的候选人。虽然讨论是容易进行的,但是实际的投票流程和运作方式,在一个成员众多的组织中,可能会有不少成员并不清…...
从Aurora看Xanadu可扩展模块化光量子计算机的现状与未来展望
从Aurora看Xanadu可扩展光量子计算机的现状与未来展望 一、引言 1.1 研究背景与意义 随着信息技术的飞速发展,经典计算机在许多领域取得了巨大的成功,但在面对一些复杂问题时,其计算能力逐渐接近极限。量子计算机作为一种新型计算设备,基于量子力学原理,能够实现并行计算…...
WPS如何添加论文中的文献引用右上角小标
给参考文献标号 1、将光标位于参考文献之前,然后点击如下图所示位置 2、点击相应的列表,然后点击确定 然后选中第一行,点击格式刷,刷一下其余行 在原文中插入右上角的引用标 1、使光标位于想插入引用光标处,点击交叉…...
如何理解语言模型
统计语言模型 先看语言模型,语言即自然语言,模型及我们要解决的某个任务。 任务一:判断哪句话出现的概率大 任务二:预判空缺的位置最有可能是哪个词 再看统计,统计即解决上述两个任务的解决方法。先对语句进行分词…...
准确-NGINX 1.26.2配置正向代理并编译安装的完整过程
NGINX 1.26.2 配置正向代理并编译安装的完整过程,使用了 ngx_http_proxy_connect_module 模块。 1. 环境准备 1.1 安装依赖 确保系统安装了以下必要的依赖: sudo yum install -y gcc gcc-c make pcre-devel zlib-devel openssl-devel1.2 下载 NGINX 源…...
企业如何将ERP和BPM项目结合提升核心竞争力
无论是实施ERP项目还是BPM项目,企业变革的根本目的的确是为了让企业变得更加强大,更具竞争力。 这就像是练武功,无论是学习少林拳还是太极拳,最终的目标都是为了强身健体,提升战斗力。 如何将ERP和BPM项目有效结合以及…...
Linux内核以太网驱动分析
1.网络接口卡接收和发送数据在Linux内核中的处理流程如下: 1. 网络接口卡(Network Interface Card, NIC) 作用:负责物理层的数据传输,将数据包从网络介质(如以太网线)读取到内存中,或…...
安宝特方案丨XRSOP人员作业标准化管理平台:AR智慧点检验收套件
在选煤厂、化工厂、钢铁厂等过程生产型企业,其生产设备的运行效率和非计划停机对工业制造效益有较大影响。 随着企业自动化和智能化建设的推进,需提前预防假检、错检、漏检,推动智慧生产运维系统数据的流动和现场赋能应用。同时,…...
视频字幕质量评估的大规模细粒度基准
大家读完觉得有帮助记得关注和点赞!!! 摘要 视频字幕在文本到视频生成任务中起着至关重要的作用,因为它们的质量直接影响所生成视频的语义连贯性和视觉保真度。尽管大型视觉-语言模型(VLMs)在字幕生成方面…...
sqlserver 根据指定字符 解析拼接字符串
DECLARE LotNo NVARCHAR(50)A,B,C DECLARE xml XML ( SELECT <x> REPLACE(LotNo, ,, </x><x>) </x> ) DECLARE ErrorCode NVARCHAR(50) -- 提取 XML 中的值 SELECT value x.value(., VARCHAR(MAX))…...
Module Federation 和 Native Federation 的比较
前言 Module Federation 是 Webpack 5 引入的微前端架构方案,允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...
回溯算法学习
一、电话号码的字母组合 import java.util.ArrayList; import java.util.List;import javax.management.loading.PrivateClassLoader;public class letterCombinations {private static final String[] KEYPAD {"", //0"", //1"abc", //2"…...
浪潮交换机配置track检测实现高速公路收费网络主备切换NQA
浪潮交换机track配置 项目背景高速网络拓扑网络情况分析通信线路收费网络路由 收费汇聚交换机相应配置收费汇聚track配置 项目背景 在实施省内一条高速公路时遇到的需求,本次涉及的主要是收费汇聚交换机的配置,浪潮网络设备在高速项目很少,通…...
Caliper 负载(Workload)详细解析
Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...
wpf在image控件上快速显示内存图像
wpf在image控件上快速显示内存图像https://www.cnblogs.com/haodafeng/p/10431387.html 如果你在寻找能够快速在image控件刷新大图像(比如分辨率3000*3000的图像)的办法,尤其是想把内存中的裸数据(只有图像的数据,不包…...
Python竞赛环境搭建全攻略
Python环境搭建竞赛技术文章大纲 竞赛背景与意义 竞赛的目的与价值Python在竞赛中的应用场景环境搭建对竞赛效率的影响 竞赛环境需求分析 常见竞赛类型(算法、数据分析、机器学习等)不同竞赛对Python版本及库的要求硬件与操作系统的兼容性问题 Pyth…...
消息队列系统设计与实践全解析
文章目录 🚀 消息队列系统设计与实践全解析🔍 一、消息队列选型1.1 业务场景匹配矩阵1.2 吞吐量/延迟/可靠性权衡💡 权衡决策框架 1.3 运维复杂度评估🔧 运维成本降低策略 🏗️ 二、典型架构设计2.1 分布式事务最终一致…...
