#define如何在编程中使用运算符定义有值?

时间:2017-10-20 06:36:57

标签: c++ c

我正面临着理解#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

4 个答案:

答案 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

了解C Preprocessor and Macros

答案 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