理解Makefile中的变量引用与展开

需积分: 4 15 下载量 87 浏览量 更新于2024-08-09 收藏 978KB PDF 举报
"变量的引用在Makefile中扮演着核心角色,它允许我们存储和重用命令、文件名或其他数据。在Makefile中,变量可以通过两种形式引用:`$(VARIABLE_NAME)`或`${VARIABLE_NAME}`。例如,如果定义了变量`foo`,我们可以用`$(foo)`或`${foo}`来获取其值。需要注意的是,由于美元符号`$`在Makefile中有特殊含义,所以在命令或文件名中使用时,需要写成`$$`来表示一个单一的`$`。 在上面的例子中,`objects`变量保存了`.o`文件的列表,然后在构建`program`时,通过`$(objects)`引用这些对象文件。当规则`$(objects) : defs.h`被展开时,这意味着所有`.o`文件都依赖于`defs.h`。规则`foo = c`和随后的`prog.o : prog.$(foo)`等展示了变量展开的过程,它类似于C语言中的宏展开,是一个简单的文本替换。在这个例子中,即使`foo`的值有前导空格,它们也会在展开时被忽略。 Makefile中的变量展开是一个严格的过程,变量值被精确替换到引用的位置。然而,对于简单的单字符变量,我们可以直接使用`$x`的形式引用,比如自动化变量。对于多字符变量,必须使用括号`$()`或`${ }`来确保正确识别变量名,否则只有首字母会被当作变量,如`$PATH`。 此外,Makefile的编写还涉及到其他概念,如Makefile的结构、规则的定义、依赖关系、通配符的使用、目录搜索、静态模式规则等。例如,`make`会根据规则来决定哪些文件需要更新,如何更新,并执行相应的命令。在处理通配符时,可以使用`wildcard`函数来获取匹配的文件名。目录搜索允许我们在多个目录中查找依赖文件,`VPATH`和`vpath`关键字分别提供了全局和局部的搜索路径设置。 理解并熟练掌握Makefile中的变量引用及其展开机制是编写高效、可维护的构建脚本的关键。在实际应用中,应避免过度复杂的变量使用,以防止引入不必要的复杂性和错误。"