Makefile 自动化变量以及模式匹配

avatar
作者
猴君
阅读量:4

1. 自动化变量

Makefile中的自动化变量可以大大简化Makefile的书写,使其更加简洁和易于维护。这些变量在规则的命令中被自动赋值,根据当前目标和依赖的上下文来确定具体的值。下面是一些常用的自动化变量:

$@  " 表示目标文件 
$<  " 表示第一个依赖文件 
$^  " 表示所有的依赖文件 

2. 模式匹配

使用模式匹配通常能匹配多个目标文件,避免了重复书写

2.1 匹配的规则

%.target : %.source 	<command> 

其中 % 是一个通配符,代表任意数量的字符。比如,要从多个.c文件编译出.o文件,你可以使用如下模式规则:

%.o : %.c 	$(CC) $(CFLAGS) -c $< -o $@ 

2.2 匹配的规则

多模式匹配

%.o: %.c %.h 	$(CC) $(CFLAGS) -c $< -o $@ 

这条规则意味着每个.o文件不仅取决于对应的.c文件,还取决于同名的.h文件。如果.c或.h文件发生变化,对应的.o文件将被重新编译。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!