makefile

本文详细介绍了Makefile的使用,包括目标、依赖和处理动作的概念,以及make工具的工作原理。通过实例展示了如何编写Makefile,包括基础规则、函数如wildcard和patsubst的应用,并解释了自动变量$@、$^和$<的用法。此外,还讨论了模板规则、静态模式规则、伪目标和第三方库的添加,旨在帮助读者掌握Makefile的高级技巧。
摘要由CSDN通过智能技术生成

1 学习目标
网上对于makefile总结学习文章有许多,但是大部分排版或者内容杂乱无章,所以还是自己进行一个总结学习,大家可以根据自己的阅读习惯选择适合自己的文章。
在实例部分的代码是层层递进改变,每一次都是在之前的基础上修改。

了解Make工具给我们带来的好处和便利
makefile的书写格式、关键字、函数。像C 语言有自己的格式、关键字和函数一样(重点)
2 makefile概述
make工具是一个根据makefile文件内容,针对目标(可执行文件)进行依赖性检测(要生成该可执行文件之前要有哪些中间文件)并执行相关动作(编译等)的工具 。而这个makefile文件类似一个脚本,其中内容包含make所要进行的处理动作以及依赖关系。

3 目标、依赖、处理动作的概念(重要)
学习make工具,需要明白三个概念:目标、依赖、处理动作。makefile所要进行的主要内容是明确目标、明确目标所依赖的内容、明确依赖条件满足时应该执行对应的处理动作。例如我们最终要实现a这个目标,但是需要依赖b,而b依赖于c的存在,则可以描述为:

a:b
cmdbtoa
b:c
cmdctob
//---------------中文表示如下--------------
目标:依赖条件
(一个tab缩进)命令
目标:依赖条件
(一个tab缩进)命令

" : "代表依赖,另外每个处理动作之前都要用tab键分隔。
上述四行的意思是:a依赖于b,而处理cmdbtoa;b依赖于c,而处理cmdctob。
4 makefile 基础规则
在网上一个比较好的视频学习中总结了一个口诀规则:

一个规则
二个函数
三个自动变量
4.1 一个规则的概念
目标的时间必须晚于依赖条件的时间,否则,更新目标
依赖条件如果不存在,找寻新的规则去产生依赖条件。
makefile的依赖是从上至下的,换句话说目标文件是第一句里的目标,如果不满足执行依赖,就会继续向下执行。如果满足生成目标的依赖,就不会再继续向下执行了。make会自动寻找规则里需要的材料文件,执行规则下面的行为生成规则中的目标。
4.2 两个函数的概念
为了方便学习,我们可以把

wildcard、patsubst看做C语言的函数名。
src、obj 看成变量名(表示函数的返回值)
函数名后面跟着的./.c %.c, %.o看做函数的参数,根据顺序可以看做参数一、参数二、参数三
src = $(wildcard ./
.c): 作用:匹配当前工作目录下的所有.c 文件。将文件名组成列表,赋值给变量 src。等价于 src = add.c sub.c div1.c
obj = $(patsubst %.c, %.o, $(src)):作用 将参数 3 中,包含参数 1 的部分,替换为参数 2。等价于obj = add.o s

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值