条件判断语句
1、makefile中支持条件判断语句
- 可以根据条件的值来决定make的执行
- 可以比较2个不同变量或者变量和常量值
ifxxx (arg1,arg2)
#for ture
else
#for false
endif
2、注意事项
条件判断语句只能用于控制make实际执行的语句;但,不能控制规则中命令的执行。
3、条件判断语句的语法说明
- 常用形式
ifxxx (arg1,arg2)
- 其他合法形式
ifxxx “arg1” “arg2”ifxxx ‘arg1’ ‘arg2’ifxxx “arg1” ‘arg2’ifxxx ‘arg1 “arg2”

4、条件判断关键字
| 关键字 | 功能 |
|---|---|
| ifeq | 判断参数是否相等,相等为true,否则为false |
| ifneq | 判断参数是否不相等,不相等为true,否则为false |
| ifdef | 判断变量是否有值,有值为true,否者为false |
| ifndef | 判断变量是否没有值,没有值为true,否者为false |
5、编程实验
.PHONY : test
var1 := A
var2 := $(var1)
var3 :=
test :
ifeq ($(var1),$(var2))
@echo "var1 == var2"
else
@echo "var1 != var2"
endif
ifneq ($(var2),)
@echo "var2 is NOT empty"
else
@echo "var2 is empty"
endif
ifdef var2
@echo "var2 is NOT empty"
else
@echo "var2 is empty"
endif
ifndef var3
@echo "var3 is empty"
else
@echo "var3 is NOT empty"
endif
//编译运行
$ make
var1 == var2
var2 is NOT empty
var2 is NOT empty
var3 is empty
6、一些工程经验
- 条件判断语句之前可以有空格,但不能有Tab字符(’\t’)
- 在条件语句中不要使用自动变量(@,@,@,^,$<)
- 一条完整的条件语句必须位于同一个makefile中
- 条件判断类似C语言中的宏,预处理阶段有效,执行阶段无效
- make在加载makefile时
- 首先计算表达式的值(赋值方式不同,计算不同)
- 根据判断语句的表达式决定执行的内容

7、编程实验
.PHONY : test
var1 :=
var2 := $(var1)
var3 =
var4 = $(var3)
#var3 = 3
test :
ifdef var1
@echo "var1 is defined"
else
@echo "var1 is NOT defined"
endif
ifdef var2
@echo "var2 is defined"
else
@echo "var2 is NOT defined"
endif
ifdef var3
@echo "var3 is defined"
else
@echo "var3 is NOT defined"
endif
ifdef var4
@echo "var4 is defined"
else
@echo "var4 is NOT defined"
endif
//编译运行
$ make
var1 is NOT defined
var2 is NOT defined
var3 is NOT defined
var4 is defined
8、小结
- 条件判断根据条件的值来决定make的执行
- 条件判断可以比较2个不同的变量或者变量和常量值
- 条件判断在预处理阶段有效,执行阶段无效
- 条件的判断不能控制规则中命令的执行过程
本文详细介绍了Makefile中的条件判断语句,包括ifeq、ifneq、ifdef和ifndef等关键字的用法,以及它们在控制make执行过程中的作用。通过编程实验展示了如何根据变量值来决定执行的指令,并强调了条件判断不能控制规则内命令执行这一特点。此外,还分享了一些工程实践经验,如条件判断前避免使用Tab字符,以及条件判断在预处理阶段有效等。
18万+

被折叠的 条评论
为什么被折叠?



