5. 预定义变量的使用

1. 自动变量与特殊变量

1.1 自动变量

$@:
当前规则中触发命令被执行的目标
$^:
当前规则中的所有依赖
$<:
当前规则中的第一个依赖

注意:“$”对于makefile有特殊含义,输出时需要加上一个“$”进行转义
5. 预定义变量的使用_第1张图片
把之前的代码改进:
5. 预定义变量的使用_第2张图片
好处:需要添加新的依赖的话,只用加一个依赖名字即可

2.2 特殊变量

  1. $(MKAE):
    当前make解释器的文件名
  2. $(MAKECMDGOALS)
    命令行中指定的目标名(make的命令行参数)
  3. $(MAKEFILE_LIST)
    make所需要处理的makefile文件列表
    当前makefile的文件名总是位于列表的最后
    文件名之间以空格进行分隔

5. 预定义变量的使用_第3张图片
5. 预定义变量的使用_第4张图片

  1. $(MAKE_VERSION)
    当前make解释器的版本
  2. $(CURDIR)
    当前make解释器的工作目录
  3. $(.VARIABLES)
    所有已经定义的变量名列表(预定义变量和自定义变量)

5. 预定义变量的使用_第5张图片

3. 小结

  1. makefile提供了预定义变量供开发者使用
  2. 预定义变量的使用能够使得makefile的开发更高效
  3. 自动变量是makefile中最常见的元素
  4. 使用$(.VARIABLES)能够获取所有的特殊元素

你可能感兴趣的:(make/makefile)