简述:Makefile 变量的定义和使用方法?Makefile模式规则中“%”的作用?Makefile 自动化"$@变量$<和$的功能? Makefile 伪目标的作用?
时间: 2024-09-06 21:03:29 浏览: 65
在Makefile中,变量的定义通常使用等号"=",变量名前可以加上"$"符号使其成为环境变量。例如:
```makefile
VAR = some value
```
要引用这个变量,直接使用$VAR即可。变量可以在命令行中替换,如$(VAR)。
`%`在模式规则中是一个特殊的占位符,代表文件名中的任何字符序列,用于匹配依赖关系中的目标文件。比如:
```makefile
%.o: %.c
gcc -c $< -o $@
```
这里`%o`表示目标文件名,`.c`表示源文件名,`$<`将自动替换为源文件的实际名称,而`$@`则会替换为目标文件的名称。
`$@`变量指的是当前正在处理的目标,`$<`则是当前活动规则链中的第一个依赖项。它们常用于生成目标文件的命令里,确保总是操作正确的输入和输出文件。
Makefile的伪目标主要有以下几个作用:
1. `.PHONY`: 用于声明那些不是由依赖关系自动触发的目标,如clean、install等,防止make误以为他们是实际存在的文件。
2. `.SUFFIXES`: 定义默认的文件扩展名到规则的映射,简化了对多个后缀支持的管理。
3. `all`: 默认的目标,当不指定目标时,make就会尝试构建它。
阅读全文