为什么" #define A"干扰"命名空间A {}"?

时间:2016-11-15 14:12:16

标签: c++ namespaces

以下代码可以编译:

namespace A{
    int i;
}
namespace B{
    int i;
}
int main(){ return 0; }

但是下面的代码无法编译:

#define A
#define B

namespace A{
    int i;
}
namespace B{
    int i;
}
int main(){ return 0; }

错误信息

  

错误:重新定义' int {anonymous} :: i'

在我定义AB之后,为什么命名空间的名称会变成匿名?

使用的编译器:gcc-4.9.3。

1 个答案:

答案 0 :(得分:13)

#define A
#define B

namespace A{
    int i;
}
namespace B{
    int i;
}

您将AB定义为什么都不是。这意味着您的代码变为

namespace {
    int i;
}
namespace {
    int i;
}

预处理器运行后。由于两个名称空间都成为匿名名称空间,因此编译器会正确地抱怨您正在重新声明i

请记住,当您定义某些内容时,预处理器将通过您的源代码完成,并用您定义的任何内容替换该符号的所有实例。你做完了吗

#define A LONG_NAME_I_DO_NOT_WANT_TO_TYPE
#define B ANOTHER_LONG_NAME_THAT_I_ALSO_DO_NOT_WANT_TO_TYPE

namespace A{
    int i;
}
namespace B{
    int i;
}

然后预处理器会将代码更改为

namespace LONG_NAME_I_DO_NOT_WANT_TO_TYPE{
    int i;
}
namespace ANOTHER_LONG_NAME_THAT_I_ALSO_DO_NOT_WANT_TO_TYPE{
    int i;
}

有关预处理器如何工作的详细信息,请参阅:GCC - The C Preprocessor