1. 自动化变量
Makefile中的自动化变量可以大大简化Makefile的书写,使其更加简洁和易于维护。这些变量在规则的命令中被自动赋值,根据当前目标和依赖的上下文来确定具体的值。下面是一些常用的自动化变量:
            
            
              bash
              
              
            
          
          $@  " 表示目标文件
            
            
              bash
              
              
            
          
          $<  " 表示第一个依赖文件
            
            
              bash
              
              
            
          
          $^  " 表示所有的依赖文件2. 模式匹配
使用模式匹配通常能匹配多个目标文件,避免了重复书写
2.1 匹配的规则
            
            
              bash
              
              
            
          
          %.target : %.source
	<command>其中 % 是一个通配符,代表任意数量的字符。比如,要从多个.c文件编译出.o文件,你可以使用如下模式规则:
            
            
              bash
              
              
            
          
          %.o : %.c
	$(CC) $(CFLAGS) -c $< -o $@2.2 匹配的规则
多模式匹配
            
            
              bash
              
              
            
          
          %.o: %.c %.h
	$(CC) $(CFLAGS) -c $< -o $@这条规则意味着每个.o文件不仅取决于对应的.c文件,还取决于同名的.h文件。如果.c或.h文件发生变化,对应的.o文件将被重新编译。