马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
这串代码中国 宏定义里的那个c为什么只替换后运算了3次
不应该是4次吗?
第一次替换后运算 c:TOUPPER(c)
第二次替换后运算 c:'a'<=(c)
第三次替换后运算 c:(c)<='z'
第四次替换后运算 c:就是最后判断条件的结果其中之一
这样打印的就会是E 可是运行是D
是TOUPPER(c)里面的这个C没有替换后运算吗?
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define TOUPPER(c) ('a'<=(c)&&(c)<='z'?(c)-'a'+'A':(c))
int main()
{
char s[5];
strcpy(s, "abcd");
int i = 0;
putchar(TOUPPER(s[++i]));
return 0;
}
宏定义中的`c`确实只被替换了三次,这是因为宏定义中的`c`只是一个符号,它不是变量,也不是表达式。宏定义只是在预处理阶段进行简单的文本替换,将代码中的`TOUPPER(s[++i])`替换成`( 'a'<=s[++i] && s[++i]<='z' ? s[++i]-'a'+'A' : s[++i] )`,因此,`c`在每次替换中都被替换成了`s[++i]`。
在这个例子中,`TOUPPER(s[++i])`被替换成了`( 'a'<=s[++i] && s[++i]<='z' ? s[++i]-'a'+'A' : s[++i] )`,其中`'a'<=s[++i]`这个条件判断会使`i`加1,然后`s[++i]`会返回`s[i+1]`的值,而不是`s[i]`的值。因此,`TOUPPER(s[++i])`中的`c`实际上被替换成了`s[i+1]`,而不是`s[i]`。所以,`TOUPPER(s[++i])`的实际运算过程是这样的:
1. `i`先加1,变成1
2. 判断`'a'<=s[2]`,这是成立的,所以继续执行
3. 判断`s[3]<='z'`,这也是成立的,所以继续执行
4. 计算`s[4]-'a'+'A'`,即`'d'-'a'+'A'`,结果为`'D'`
5. `putchar('D')`输出`D`
因此,程序输出的是`D`而不是`E`。
|