理解Makefile中的隐含变量与规则

需积分: 50 47 下载量 26 浏览量 更新于2024-08-08 收藏 1.24MB PDF 举报
"隐含变量-cfd数值模拟原理-1" 在GNU Make中,隐含变量是一种预定义的变量,它们在内嵌的隐含规则中起着关键作用。这些变量可以被用户通过多种方式重定义,如在Makefile中、通过命令行参数或设置系统环境变量。一旦重定义,make在运行时就会使用这些新的定义,除非使用“-R”或“--no-builtin-variables”选项来取消所有隐含变量及其对应的隐含规则。 例如,编译C源文件的默认隐含规则是使用`$(CC)`变量(默认值为`cc`)加上`-c`选项以及`$(CFLAGS)`和`$(CPPFLAGS)`来执行编译。如果想将`CC`变量设置为`ncc`,可以通过直接在Makefile中设置`CC = ncc`,或在命令行上使用`make CC=ncc`,甚至设置系统环境变量`CC`来实现。重定义`CFLAGS`可以添加或修改编译选项。若要确保子目录间共享相同的编译设置,需使用`export`关键字导出这些变量。 隐含变量大致分为两类:一类代表程序的名称,如`CC`表示C编译器,`AR`用于创建静态库,`AS`为汇编程序,`CXX`代表C++编译器;另一类代表执行程序时的参数,如`CFLAGS`用于存储C编译选项。为保持Makefile的清晰性和可读性,建议将参数集中的共同选项放在一个变量中,避免将参数与程序名称混在一起定义。 在编写Makefile时,遵循模块化原则,使得每个变量都有明确的职责,避免变量之间的关系过于复杂。通过合理利用隐含变量和规则,可以有效地自动化构建过程,提高开发效率。 在更广泛的上下文中,GNU Make中文手册提供了一个基础到高级的指南,涵盖了Makefile的各个方面,包括规则的定义、依赖关系、通配符使用、目录搜索、特殊目标和伪目标等。手册详细解释了如何编写和理解Makefile,以及make工具的工作原理,是理解和使用GNU Make的重要参考资料。