本文目录一览:
- 1、如何在“IFEQ'语句使用多个条件
- 2、c语言ifeq++什么意思
- 3、Android.mk/makefile 的ifeq和ifdef的区别
- 4、makefile中ifeq,ifneq,ifdef和ifndef的区别与用法
- 5、makefile中ifeq、ifneq、ifdef、ifndef的简单介绍
如何在“IFEQ'语句使用多个条件
1. 您ifeq与你的价值观的串联,如。ifeq ($(TEST_FLAG)$(DEBUG_FLAG), TRUEFALSE)
do something
endif
它也可以视情况而定的函数,这更可能在一个循环中(如ifeq可能不会做你希望在一个循环中,它会被恰好一次测试)。
2. 虽然Hasturkun的解决方案,将工作,我觉得惯用的方式来写,这是:ifeq ($(TEST_FLAG),TRUE)
ifeq ($(DEBUG_FLAG),FALSE)
# Stuff
endif
endif
c语言ifeq++什么意思
如果没猜错,ifeq是变量,ifeq++的功能是先使用ifeq的值,再将其自增一。单独使用时与
++ifeq一样,只起到自增一的作用。在被函数使用时比如printf("%d",ifeq++);会先输出ifeq的值,再自增一。而++ifeq无论何时都先自增一,再使用。
Android.mk/makefile 的ifeq和ifdef的区别
ifeq重点在eq: equal, 等于简写
例子:
ifeq ($(CC),gcc)
$(CC) -o foo $(objects) $(libs_for_gcc)
else
$(CC) -o foo $(objects) $(normal_libs)
endif
ifdef, def: define, 定义简写
ifdef只是测试一个变量是否有值,其并不会把变量扩展到当前位置。
例子
bar =
foo = $(bar)
ifdef foo
frobozz = yes
else
frobozz = no
endif
detail see
makefile中ifeq,ifneq,ifdef和ifndef的区别与用法
makefile中ifeq,ifneq,ifdef和ifndef的区别与用法
使用条件判断,可以让make根据运行时的不同情况选择不同的执行分支。条件表达式可以是比较变量的值,或是比较变量和常量的值。
一、示例
下面的例子,判断$(CC)变量是否“gcc”,如果是的话,则使用GNU函数编译目标。
libs_for_gcc = -lgnu
normal_libs =
foo: $(objects)
ifeq ($(CC),gcc)
$(CC) -o foo $(objects) $(libs_for_gcc)
else
$(CC) -o foo $(objects) $(normal_libs)
endif
可见,在上面示例的这个规则中,目标“foo”可以根据变量“$(CC)”值来选取不同的函数库来编译程序。
我们可以从上面的示例中看到三个关键字:ifeq、else和endif。ifeq的意思表示条件语句的开始,并指定一个条件表达式,表达式包含两个参数,以逗号分隔,表达式以圆括号括起。else表示条件表达式为假的情况。endif表示一个条件语句的结束,任何一个条件表达式都应该以endif结束。
当我们的变量$(CC)值是“gcc”时,目标foo的规则是:
foo: $(objects)
$(CC) -o foo $(objects) $(libs_for_gcc)
而当我们的变量$(CC)值不是“gcc”时(比如“cc”),目标foo的规则是:
foo: $(objects)
$(CC) -o foo $(objects) $(normal_libs)
当然,我们还可以把上面的那个例子写得更简洁一些:
libs_for_gcc = -lgnu
normal_libs =
ifeq ($(CC),gcc)
libs=$(libs_for_gcc)
else
libs=$(normal_libs)
endif
foo: $(objects)
$(CC) -o foo $(objects) $(libs)
二、语法
条件表达式的语法为:
conditional-directive;
text-if-true;
endif
以及:
conditional-directive;
text-if-true;
else
text-if-false;
endif
其中conditional-directive;表示条件关键字,如“ifeq”。这个关键字有四个。
第一个是我们前面所见过的“ifeq”
ifeq (arg1;, arg2;)
ifeq 'arg1;' 'arg2;'
ifeq "arg1;" "arg2;"
ifeq "arg1;" 'arg2;'
ifeq 'arg1;' "arg2;"
比较参数“arg1”和“arg2”的值是否相同。当然,参数中我们还可以使用make的函数。如:
ifeq ($(strip $(foo)),)
text-if-empty;
endif
这个示例中使用了“strip”函数,如果这个函数的返回值是空(Empty),那么text-if-empty;就生效。
第二个条件关键字是“ifneq”。语法是:
ifneq (arg1;, arg2;)
ifneq 'arg1;' 'arg2;'
ifneq "arg1;" "arg2;"
ifneq "arg1;" 'arg2;'
ifneq 'arg1;' "arg2;"
其比较参数“arg1”和“arg2”的值是否相同,如果不同,则为真。和“ifeq”类似。
第三个条件关键字是“ifdef”。语法是:
ifdef variable-name;
如果变量variable-name;的值非空,那到表达式为真。否则,表达式为假。当然,variable-name;同样可以是一个函数的返回值。注意,ifdef只是测试一个变量是否有值,其并不会把变量扩展到当前位置。还是来看两个例子:
示例一:
bar =
foo = $(bar)
ifdef foo
frobozz = yes
else
frobozz = no
endif
示例二:
foo =
ifdef foo
frobozz = yes
else
frobozz = no
endif
第一个例子中,“$(frobozz)”值是“yes”,第二个则是“no”。
第四个条件关键字是“ifndef”。其语法是:
ifndef variable-name;
这个我就不多说了,和“ifdef”是相反的意思。
在conditional-directive;这一行上,多余的空格是被允许的,但是不能以[Tab]键做为开始(不然就被认为是命令)。而注释符“#”同样也是安全的。“else”和“endif”也一样,只要不是以[Tab]键开始就行了。
特别注意的是,make是在读取Makefile时就计算条件表达式的值,并根据条件表达式的值来选择语句,所以,你最好不要把自动化变量(如“$@”等)放入条件表达式中,因为自动化变量是在运行时才有的。
而且,为了避免混乱,make不允许把整个条件语句分成两部分放在不同的文件中。
makefile中ifeq、ifneq、ifdef、ifndef的简单介绍
条件语句中使用到了三个关键字:“ifeq”、“else”和“endif”。其中:
此关键字用来判断参数是否相等,格式如下:
`ifeq 'ARG1' "ARG2"'替换展开“ARG1”和“ARG1”后,对它们的值进行比较
通常我们会使用它来判断一个变量的值是否为空(不是任何字符)。
参数值可能是通过引用变量或者函数得到的,因而在展开过程中可能造成参数值中包含空字符(空格等)。
一般在这种情况时我们使用make的“strip”函数来对它变量的值进行处理,去掉其中的空字符。
格式为:
即就是在“$(foo)”中存在若干前导和结尾空格,
“TEXT-IF-EMPTY”也会被作为Makefile需要执行的一部分。
关键字“ifneq”实现的条件判断语句和“ifeq”相反
关键字“ifdef”用来判断一个 变量 是否 已经 定义。
ifdef 只是测试一个变量是否有值,
不会对变量进行 替换展开 来判断变量的值 是否 为空。
对于变量“VARIABLE-NAME” ,除了
“VARIABLE-NAME=”这种情况以外,使用 其它方式 对它的定义都会使“ifdef”返回 真 。
就是说,
即使我们通过 其它方式 (比如,定义它的值引用了其它的变量)给它赋了一个 空值 , “ifdef”也会返回真。
举例:
例 1中的结果是:“frobozz = yes” ;
而例 2的结果是:“frobozz = no”。
其原因就是在例 1中,变量“foo”的定义是“foo = $(bar)” 。
虽然变量“bar”的值为空,
但是“ifdef”判断的结果是真。
因此当我们需要 判断一个变量的值是否为空 的情况时,
需要使用 ifeq (或者 ifneq )而不是“ifdef”