Makefile学习④:Makefile中的变量
系统变量
$* 不包括扩展名的目标文件名称
$+ 所有的依赖文件,以空格分隔
$< 表示规则中的第一个条件
$? 所有时间戳比目标文件晚的依赖文件,以空格分隔
$@ 目标文件的完整名称
$^ 所有不重复的惊赖文件,以空格分隔
$% 如果目标是归档成员,则该变量表示目标的归档成员名称
系统常量(可用make -p查看)
AS 汇编程序的名称 默认 as
CC C编译器名称 默认 cc
CPP C预编译器名称 默认 cc -E
CXX C++编译器名称 默认 g++
RM 文件删除程序别名 默认 rm -f
自定义变量
定义:变量名 = 变量值
使用: $(变量名)/$(变量名)
使用自定义变量实现模板化Makefile,如下:
使用前:
使用后:
对比上述2图,可发现使用了OBJ和TARGET自定义变量替代了原有的目标和依赖,对于后续使用可直接替换变量值即可,使得Makefile的复用性更强。
使用系统变量进行优化
此处使用系统变量,来进行等价替换
$@ 目标文件的完整名称(表示当前目标)
$^ 所有不重复的惊赖文件,以空格分隔(表示当前依赖)
替换结果如下:
使用系统常量进行优化
通过打印系统常量可以显示更改前的系统常量的值。
如下所示:
由上图可以发下,编译命令和删除命令是可以使用系统常量进行替换的,替换后如下图所示:
使用系统常量进行编译的等价替换,使得Makefile脚本的可移植性更强,跨平台性也更强,更加方便大项目的跨平台使用。