我正面临着理解#define如何运作的问题。
#include<stdio.h>
#define x 6+3
int main(){
int i;
i=x; //9
printf("%d\n",i);
i=x*x; //27
printf("%d\n",i);
i=x*x*x; //45
printf("%d\n",i);
i=x*x*x*x; //63
printf("%d\n",i);
return 0;
}
如果我使用#define x 6+3
,则输出为9 27 45 63
如果我使用#define x (6+3)
,则输出为9 81 729 6561
答案 0 :(得分:5)
#define
只是将字符标记(在您的情况下为x
)替换为您定义的字符标记。
因此,在预处理器完成其工作后,您的示例将如下所示:
#include<stdio.h>
#define x 6+3
int main(){
int i;
i=6+3; //9
printf("%d\n",i);
i=6+3*6+3; //27
printf("%d\n",i);
i=6+3*6+3*6+3; //45
printf("%d\n",i);
i=6+3*6+3*6+3*6+3; //63
printf("%d\n",i);
return 0;
}
如果你仔细研究它就会明白为什么,例如第二个例子是27而不是81(*之前的+)。
另一方面,如果你写(6 + 3)它将是9 * 9,这就是你所期望的。
答案 1 :(得分:2)
这是运算符优先级的情况。你可以稍微研究一下。我在这个问题上描述如下。
如果您使用
#define x 6+3
然后
x = 6+3= 9
x*x = 6+3 * 6+3 = 6+18+3 = 27 (as * has higher precedence as operator than + ; so 3*6 will be evaluated earlier )
同样继续。
现在,如果您使用
#define x (6+3)
然后
x = (6+3) = 9
x*x = (6+3)*(6+3) = 9*9 = 81
同样继续。
所以我的建议是始终使用括号以获得更好的可读性和理解。
答案 2 :(得分:1)
宏的名称由内容替换。这意味着
#define x 6+3
x*x*x*x = 6+3*6+3*6+3*6+3 = 6+18+18+18+3
将x定义为插入(6 + 3) - (6 + 3)时。这意味着
#define x (6+3)
x*x*x*x = (6+3)*(6+3)*(6+3)*(6+3) = 9*9*9*9
答案 3 :(得分:1)
宏扩展是文本替换。所以
#define x 6 + 3
#define y (6+3)
提供以下内容
printf( "%d %d\n", x , y ); // 6 +3 , (6+3) is 9 and 9
printf( "%d %d\n", x *x , y * y ); // 6 + 3 * 6 + 3, (6+3) * (6+3)
// 6 + 18 + 3 , 9 * 9
// 27 , 81