加qq:1126137994 微信:liu1126137994 一起学习更多技术~

今天来学习Makefile中条件判断语句!

Makefile也算是一门语言,它有自己的语法,那么它应该也会像C/C++语言一样,支持条件判断语句!

Makefile中的条件判断语句:

  • 可以根据条件的值来决定make的执行
  • 可以比较两个不同的变量或者变量和常量的值
ifxxx (arg1,arg2)
#for true
else
#for false
endif

注意事项:
条件判断语句只能用于控制make实际执行的语句,但是不能控制规则中命令的执行过程!!!

条件判断语句的语法说明:

  • 常用形式
ifxxx (arg1,arg2)
  • 其他合法形式
ifxxx "arg1","arg2"
ifxxx 'arg1','arg2'
ifxxx "arg1",'arg2'
ifxxx 'arg1',"arg2"

注意下图的问题:
判断语句前面可以是空格,但不能是tab键

条件判断关键字:

下面看一个例子,来加深对上述理论的理解:

.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后有这个错误:

这个错误实际上是,判断语句前面应该是空格,而我的判断语句前面都是tab字符,我将判断语句前面的tab键全部删除换成空格后,就可以了!
修改后,运行make显示:

下面总结的是Makefile中判断语句的一些工程上的经验:

  1. 条件判断语句之前可以有空格,但是不能有tab键(’\t’)
  2. 在条件判断语句中,不要使用自动变量$@ $^ $<
  3. 一个完整的条件判断语句,必须位于同一个makefile中
  4. 条件判断语句类似于C语言中的宏,预处理阶段有效,执行阶段无效
  5. make在加载makefile时

    *首先计算表达式的值(赋值方式不同,计算方式不同)
    根据判断语句的表达式*,决定执行的内容

分析一下,下图中的两个代码,输出是相同的么:

看看下面的代码:

.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后显示:

总结:

  1. 条件判断语句根据条件的值来决定make的执行
  2. 条件判断可以比较两个不停变量或者变量和常量
  3. 条件判断在预处理阶段有效,在执行阶段无效
  4. 条件判断不能控制规则中命令的执行过程

想一起探讨以及获得各种学习资源加我:
qq:1126137994
微信:liu1126137994
可以共同交流关于嵌入式,操作系统,C++语言,C语言,数据结构等技术问题。