makefile:
//基本语法:
目标:依赖项
命令1
命令2
...
//依赖相与目标相之间的关系:
目标相是文件,makefile会检查时间戳,如果依赖相的时间戳比目标相的时间戳要新,或者目标相不存在,则会执行相应命令来更新文件
如果目标相是操作名(all,clean...),则不会检查时间戳,直接执行命令
如果目标相依赖相中包含其他目标相,则makefile会递归调用
//预定义变量:
CC --- 指定对应的编译器
SRC --- 源文件
OBJ --- 生成的目标文件
//注意:不想回显对应的执行信息的,可以在前面加@
//伪目标:.PHONY
作用:防止由于文件与目标重名,导致makefile执行时跳过执行对应目标
伪目标只是一个标签
示例:
.PHONY: 目标1 目标2 ...
//makefile的嵌套:
subsystem:
cd subdir && $(MKAE) MAKE宏 --- 等价make指令
//去到subdir这个目录,执行makefile
等价于:
subsystem:
$(MAKE) -C subdir
//一般把这个makefile称为总控makefile,总控makefile的变量可以传递到下一级makefile,但不会覆盖下一级变量
//变量的传递:
export声明:允许变量传递到下一级
unexport声明:不允许变量传递到下一级
示例:
export var = value 等价于 var = value export var
export var := value 等价于 var := value export var
//注意:如果想传递所有变量的话,可以直接export后面什么也不跟
//指定头文件路径
-I
//指定库文件路径
-L --- 库文件路径
-l --- 具体库文件
$@ --- 规则中目标文件名
$< --- 第一个依赖目标名
$^ --- 所有依赖目标名,以空格分开
$(@D) --- 目标文件所在目录名
$(@F) --- 目标文件的文件名(不包含路径)
$+ --- 表示规则中所有依赖文件名,以出现的先后顺序
//延时变量:执行时赋值
A = XXX
B ?= xxx //没有赋值则赋值,若之前赋值过,则无效
D += xxx //如果D在之前是延时变量,那么他现在还是延时变量
//即使变量:
C := xxx //变量C被立即赋值
//通配符:
* --- 匹配0个或任意多字符
? --- 匹配一个任意字符
[...] --- 匹配方括号内任意一个字符
[!...] --- 匹配除了方括号内的字符之外的任意一个字符
% --- 通常与%.c %.o,表示任意.c或.o文件
//常用函数:
//函数调用的一般格式:
$(function arguments)
//1.$(foreach,var,list,text) --- 将list中每个元素修改为text对应的文本格式,再将值赋予var
var --- 列表中的每个元素
list --- 对应元素列表(元素由空格和换行符分割)
text --- 对应文本格式
示例:
objs := a.o b.o
dep_file := $(foreach f,$(objs),$(f).txt)
all:
@echo $(dep_file)
#dep_file的最终值是a.o.txt b.o.txt
//2.$(wildcard pattern) --- 验证pattern对应的文件是否存在,若存在则将所有值列出来
示例:
src_file := $(wildcard *.c)//将文件夹中的所有.c文件列出来,将文件名存储到src_file变量中
//3.$(subst from,to,text) --- 文本替换,将text中的from处的字符替换为,to代表的字符
示例:
txt1 := feet on the street
txt2 := $(subst ee,哈哈,$(txt1))
all:
@echo $(txt2)
//f哈哈t on the str哈哈t
//4.$(patsubst pattern ,replacement,text) --- 寻找text中符合pattern格式的字符串,用replacement处的文字代替
示例:
GG := $(patsubst %.c,%.o,jjj.c hello.k.c)
all:
@echo $(GG)
//输出:jjj.c hello.k.c被修改为jjj.o hello.k.o
//5.$(strip string) --- 去掉字符串的前导空格和结尾空格,将中间的多个空格压缩为一个空格
示例:
EE := $(strip a b c )
all:
@echo $(EE)
输出结果为:a b c
//6.$(findstring find,in) --- 在in字符串中寻找find代表的字符串,找到返回对应字符串,未找到返回空
示例:
str1 := nihaoa
str2 := $(findstring ha,$(str1))
all:
@echo $(str2)
输出结果为:ha
//7.$(filter pattern...,text) --- 去除过滤掉text文本段中不符合pattern...格式的部分,text文本段中用空格进行分割
示例:
KK := $(filter %.c %.o,99.c ji.o ajda.s jdla.h)
all:
@echo $(KK)
输出结果为:99.c ji.o
//8.$(filter-out pattern..., text) --- 过滤掉文本段中符合pattern...部分(filter的反函数)
示例:
aa := $(filter-out %.c %.o,99.c ji.o ajda.s jdla.h)
all:
@echo $(aa)
输出结果:ajda.s jdla.h
//9.$(sort list) --- 将list中的元素,按照字母顺序排序,参考字母是首字母
示例:
bb := $(sort nj dla ajk)
all:
@echo $(bb)
输出结果:ajk dla nj