makefile--if条件判断语句语法与使用

条件判断语句


1. makefile中支持条件判断语句

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

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


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

  • 常用形式
    ifxxx (arg1,arg2)
  • 其它合法形式
    ifxxx “arg1” “arg2”
    ifxxx ‘arg1’ ‘arg2’
    ifxxx “arg1” ‘arg2’
    ifxxx ‘arg1’ “arg2”


    8-1 if格式.png

3. 条件判断关键字

关键字 功能
ifeq 判断参数是否相等,相等为true,否则为false
ifneq 判断参数是否不相等,不相等为true,否则为false
ifdef 判断参数是否有值,有值为true,否则为false
ifndef 判断参数是否没有值,没有值为true,否则为false
.PHONY : test

var1 := A
var2 := $(var1)
var3 := 

test :
    ifeq ($(var1),$(var2))
    @echo "var1 == var2"
    else
    @echo "var1 != var2"
    endif

    ifneq ($(var3), )
    @echo "var3 is not empty"
    else
    @echo "var3 is empty"
    endif

    ifdef var1
    @echo "var1 is not empty"
    else
    @echo "var1 is empty"
    endif

    ifndef var3
    @echo "var3 is empty"
    else
    @echo "var3 is not empty"
    endif

8_1.PNG

4.一些工程经验

  • 条件判断语句之前可以有空格,但不能有Tab字符(’\t’)
  • 在条件语句中不要使用自动变量(@,^,$<)
  • 一条完整的条件语句必须位于同一个makefile中
  • 条件判断类似C语言中的宏,预处理阶段有效执行阶段无效
  • make在加载makefile时
    首先计算表达式的值(赋值方式不同,计算方式不同)
    根据判断语句的表达式决定执行的内容

小结:

  • 条件判断根据条件的值决定make的执行
  • 条件判断可以比较两个不同变量或者变量和常量值
  • 条件判断在预处理阶段有效,执行阶段无效
  • 条件判断不能控制规则中命令的执行过程
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 来自陈浩的一片老文,但绝对营养。 示例工程:3 个头文件*.h,和 8 个 C 文件*.c。 初 编译过程,源文件...
    周筱鲁阅读 4,754评论 0 17
  • 使用条件判断 使用条件判断,可以让make根据运行时的不同情况选择不同的执行分支。条件表达式可以是比较变量的值,或...
    Stan_Z阅读 994评论 0 6
  • 第2章 基本语法 2.1 概述 基本句法和变量 语句 JavaScript程序的执行单位为行(line),也就是一...
    悟名先生阅读 4,238评论 0 13
  • VR作为新型的高科技技术,从开始到现在,一直广受关注,谷歌、微软、三星、高通等全球性企业先后入局VR行业,并在建立...
    邦悦信息阅读 418评论 0 0
  • 在ES5中,var命令会发生”变量提升“现象,即变量可以在声明之前使用,值为undefined。这种现象多多少少是...
    邪筱步阅读 278评论 0 3