Makefile基本结构
Makefile是Make读入的惟一配置文件,因此本节的内容实际就是讲述Makefile的编写规则。在一个Makefile中通常包含如下内容:
· 需要由make工具创建的目标体(target),通常是目标文件或可执行文件;
· 要创建的目标体所依赖的文件(dependency_file);
· 创建每个目标体时需要运行的命令(command)。
它的格式为:
target: dependency_files
command
Makefile中常见自动变量
命令格式 含 义
$* 不包含扩展名的目标文件名称
$+ 所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件
$< 第一个依赖文件的名称
$? 所有时间戳比目标文件晚的依赖文件,并以空格分开
$@ 目标文件的完整名称
$^ 所有不重复的依赖文件,以空格分开
$% 如果目标是归档成员,则该变量表示目标的归档成员名称
模式规则是用来定义相同处理规则的多个文件的。它不同于隐式规则,隐式规则仅仅能够用make默认的变量来进行操作,
而模式规则还能引入用户自定义变量,为多个文件建立相同的规则,从而简化Makefile的编写
相关文件前必须用“%”标明
%.o : %.c
$(CC) $(CFLAGS) -c $< -o $@
所有.o文件依赖所有相应c文件,用同样规则 |