Linux之Makefile(目标指定变量)

来源:互联网 发布:时空大数据云平台 编辑:程序博客网 时间:2024/05/16 00:53
设置一个目标指定变量的语法为: 
  
TARGET ... : VARIABLE-ASSIGNMENT 
 
或者: 
 
TARGET ... : override VARIABLE-ASSIGNMENT 
 
一个多目标指定的变量的作用域是所有这些目标的上下文,它包括了和这个目标相关的
所有执行过程。 
目标指定变量的一些特点: 
1.  “VARIABLE-ASSIGNMENT”可以使用任何一个有效的赋值方式, “=” (递
归)、“:=”(静态)、“+=”(追加)或者“?=”(条件)。 
2.  使用目标指定变量值时,目标指定的变量值不会影响同名的那个全局变量的值。
就是说目标指定一个变量值时,如果在 Makefile 中之前已经存在此变量的定义
(非目标指定的),那么对于其它目标全局变量的值没有变化。变量值的改变只
对指定的这些目标可见。 
3.  目标指定变量和普通变量具有相同的优先级。就是说,当我们使用 make 命令
行的方式定义变量时,命令行中的定义将替代目标指定的同名变量定义(和普
通的变量一样会被覆盖)。另外当使用make的“-e”选项时,同名的环境变量
也将覆盖目标指定的变量定义。因此为了防止目标指定的变量定义被覆盖,可
以使用第二种格式,使用指示符“override”对目标指定的变量进行声明。 
 
4.  目标指定的变量和同名的全局变量属于两个不同的变量,它们在定义的风格(递
归展开式和直接展开式)上可以不同。 
5.  目标指定的变量变量会作用到由这个目标所引发的所有的规则中去。例如: 
     
prog : CFLAGS = -g 
prog : prog.o foo.o bar.o 
    
这个例子中,无论 Makefile 中的全局变量“CFLAGS”的定义是什么。对于目
标“prog”以及其所引发的所有(包含目标为“prog.o”、“foo.o”和“bar.o”的所有
规则)规则,变量“CFLAGS”值都是“-g”。 
使用目标指定变量可以实现对于不同的目标文件使用不同的编译参数。看一个例
子: 
# sample Makefile 
 
CUR_DIR = $(shell pwd) 
INCS := $(CUR_DIR)/include 
CFLAGS := -Wall –I$(INCS) 
 
EXEF := foo bar 
 
.PHONY : all clean 
all : $(EXEF) 
 
foo : foo.c 
foo : CFLAGS+=-O2 
bar : bar.c 
bar : CFLAGS+=-g 
……….. 
……….. 
 
$(EXEF) : debug.h 
$(CC) $(CFLAGS) $(addsuffix .c,$@) –o $@ 
 
clean : 
  $(RM) *.o *.d $(EXES) 
 
这个 Makefile 文件实现了在编译程序“foo”使用优化选项“-O2”但不使用调试选项
“-g”,而在编译“bar”时采用了“-g”但没有“-O2”。这就是目标指定变量的灵活之
处。
0 0