目录
1.makefile中支持条件判断语句
- 可以根据条件的值来决定make的执行
- 可以比较两个不同变量或者变量和常量值
2.注意事项
条件判断语句只能用于控制make实际执行的语句;但是不能控制规则命令的执行过程
3.条件判断语句的语法说明
4.条件判断关键字
示例
.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
示例二
.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
5.一些工程经验
- 条件判断语句之前可以由空格,但不能有Tab字符(‘\t’)
- 在条件语句中不要使用自动变量($@ $^ $<)
- 一条完整的条件语句必须位于同一个makefile中
- 条件判断类似C语言中的宏,预处理阶段有效,执行阶段无效
- make在加载makefile时
首先计算表达式的值(赋值方式不同,计算方式不同)
根据判断语句的表达式决定执行的内容
6.下面的代码的输出相同吗?
7.小结
- 条件判断根据条件的值来决定make的执行
- 条件判断可以比较两个不同变量或者变量和常量值
- 条件判断在预处理阶段有效,执行阶段无效
- 条件判断不能控制规则中的命令的执行过程