Makefile 文件命名和规则
- 文件命名
- makefile 或者 Makefile
- Makefile 规则
- 一个 Makefile 文件中可以有一个或者多个规则
目标 ... : 依赖 ...`命令 (shell 命令)...
- 目标:最终要生成的文件,伪目标除外
- 依赖:生成目标所需的文件或是目标
- 命令:通过执行命令对依赖操作生成目标(命令前必须 Tab 缩进)
- 一个 Makefile 文件中可以有一个或者多个规则
工作原理
- 命令在执行前,需要先检查规则中的依赖是否存在
- 如果存在,执行命令
- 如果不存在,向下执行其他的规则,检查有没有一个规则是用来生成这个依赖的,如果找到了,则执行该规则的命令
- 检测更新,在执行规则中的命令时,会比较目标和依赖文件的时间
- 如果依赖的时间比目标的时间晚,需要重新生成目标
- 如果依赖的时间比目标早,目标不需要更新,对应规则中的命令不需要被执行
变量
预定义的变量
AR :归档维护程序的名称,默认值 ar
CC : C 编译器的名称,默认值为 cc
CXX :C++ 编译器的名称,默认值为 g++
$@
:目标的完整名称
**<∗∗:第一个依赖文件的名称‘<**:第一个依赖文件的名称 `<∗∗:第一个依赖文件的名称‘^`:所有的依赖文件
获取变量的值
$(变量名)
函数
$(wildcard PATTERN ...)
- 功能: 获取指定目录下指定类型的文件列表
- 参数:PATTERN 指的是某个或多个目录下的对应的某种类型的文件,如果有多个目录,一般使用空格间隔。
- 返回:得到的若干个文件的文件列表,文件名之间使用空格间隔
- 示例:
$(wildcard *.c ./sub/*.c)
返回值格式:a.c b.c c.c d.c e.c .f.c
$(patsubst <pattern>,<replacement>,<text>)
- 功能:查找
中的单词(单词以空格、tab 或者回车、换行 分隔) 是否符合模式 pattern ,如果匹配的话,则以 replacement 替换。 - pattern 可以包括通配符
%
, 表示任意长度的字符串。如果 replacement 中也包含%
,那么 ,replacement 中的这个%
将是 pattern 中的那个%
所代表的字串,可以用\
来转义,以\%
来表示真实含义的%
字符 - 返回:函数返回被替换过后的字符串
- 示例 :
$(patsubst %.c,%.o, x.c bar.c)
返回格式:x.o bar.o