【问题标题】:A way to use all the unqualified names in a C++0x enum class?一种在 C++0x 枚举类中使用所有非限定名称的方法?
【发布时间】:2011-11-19 09:36:44
【问题描述】:

新的 C++(C++0x 或 C++11)有一种新的枚举类型,一个“枚举类”,其中名称的范围为枚举(除其他外)。

enum class E {
    VAL1, VAL2
};

void fun() {
    E e = E::VAL1;  // Qualified name
}

不过,我想知道是否可以在特定范围内选择性地使用非限定名称。比如:

void fun() {
    using E::*;
    E e = VAL1;
    switch (e) {
        case VAL2: ...

我知道我可以写using E::VAL1 并得到一个值。但我不想对更大枚举的每个值都这样做。

【问题讨论】:

  • 如果我可能会问,您使用的是什么编译器?能够“使用 E::Val1;”的错误报告是有序的。
  • 几年前我错过了这条评论。它曾经是,现在仍然是,铿锵声。现在是 4.0 版。
  • clang4 还没有得到这个吗?奇怪。我正在/正在工作 gcc - 现在是 4.8。这在那里有效。

标签: enums c++11 using-declaration


【解决方案1】:

在 C++11 中没有办法做到这一点。以防万一您不知道 - 即使对于无范围的枚举,您也会得到 E::Val1 表示法。对于这样的枚举,您可以使用和不使用E:: 访问Val1

但是您不能采用范围枚举并选择性地使其所有枚举器在给定范围内可见。还应注意,您可以using E::Val1。规范明确禁止这样做,您的编译器还没有拒绝它。

【讨论】:

  • 对于好奇的人,第 7.3.3/7 节为“使用声明不应命名范围枚举器。”
【解决方案2】:

这也是我碰巧想要的,但还没有尝试解决。这是一个未经测试的解决方案。 编辑:我试过了,效果很好!这是我的第一个 C++11 实用程序宏。我还添加了一个过去的枚举器,以帮助将其扩展到“派生”枚举。

#define IMPORTABLE_ENUM( TYPENAME, ... ) \
\
struct import_ ## TYPENAME { \
    enum TYPENAME { \
        __VA_ARGS__ \
    }; \
}; \
\
typedef import_ ## TYPENAME :: TYPENAME TYPENAME;

这不能导入到块作用域中,但定义了一个基类import_duck 以将枚举器带入一个类。用法:

IMPORTABLE_ENUM ( duck, huey, dewey, louie )

duck d = duck::dewey; // can't use unscoped enumerators here

struct duck_madness : private import_duck { // but inside a derived class
    duck who_did_it() { return huey; } // qualification is unnecessary
}

而且由于即使在派生类中也只有一个enum 类型,所以不需要static_cast

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2010-10-25
    • 2013-05-16
    • 1970-01-01
    • 2011-03-03
    • 1970-01-01
    相关资源
    最近更新 更多