C 宏,奇怪的东西

问题描述 投票:0回答:2

尝试在 C 宏中找出一些简单的东西, 例如像这样的代码:

#include <stdio.h> 
#define MACRO(b)  printf("%d\n", b*b)

int main()
{
    MACRO(4+1); 
}

这段代码的输出是9,我认为它应该是25。 我不知道为什么以及如何结果是 9 而不是 25。

c
2个回答
2
投票

当您使用宏时,预处理器会逐字替换它及其参数,因此代码中的宏扩展将如下所示

printf("%d\n", 4+1*4+1);

这不会为你提供你想要的结果,这也是类似函数的宏被看不起的原因之一。

您需要使用括号来确保不会出现此问题:

#define MACRO(b)  printf("%d\n", (b)*(b))

while 将导致以下扩展:

printf("%d\n", (4+1)*(4+1));

每当您遇到与预处理器相关的问题时,几乎所有编译器都可以选择在预处理阶段后停止,这使您可以查看预处理的源代码,这将帮助您解决此类问题。


另请注意,另一个这里可能出现的问题是,如果您作为参数传递给宏的表达式是例如具有某些副作用的函数调用,该函数将被调用两次,并且副作用将发生两次,即使使用括号也是如此。

一个简单的例子,使用你的宏:

int my_function(void)
{
    printf("Foo\n");
    return 1;
}

int main(void)
{
    MACRO(my_function());
}

上面的程序将打印

"Foo\n"
两次。如果
MACRO
是一个正确的函数,则对
my_function
的调用只会发生一次,并且该函数的打印输出也只会发生一次。


1
投票

在宏两边加上括号,以正确的顺序计算参数:

#include <stdio.h> 
#define MACRO(b)  printf("%d\n", (b)*(b))

int main()
{
    MACRO(4+1); 
}
© www.soinside.com 2019 - 2024. All rights reserved.