将值添加到C ++枚举

时间:2015-12-17 13:42:49

标签: c++ c++11 enums

假设我在另一个无法更改的库中有以下代码

typedef enum {
    p0  = 0,
    p1  = 1,
    p2  = 2,
    p3  = 3,
    p4  = 4,
    p5  = 5,
    p6  = 6,
    ...
} PinName;

我想添加一些额外的别名(不使用const PinName PIN_... ):

enum class : PinName {
    PIN_SD_MOSI = p0,
    PIN_SD_MISO = p4,
    PIN_SD_SCK = p2,
    PIN_SD_CSN = p6,
};

但它不起作用。我收到以下错误:

error: underlying type 'PinName' of '<anonymous enum class>' must be an integral type
  enum class : PinName {
               ^

我也尝试使用enum class : int {但是别名从不在范围内 - 我怀疑我必须使用普通enumenum : int编译,但是你不能将任何别名传递给PinName的函数。你收到这个错误:

error: no matching function for call to 'foo(<anonymous enum>, <anonymous enum>)'
 foo(PIN_SD_MISO, PIN_SD_MOSI);
     ^

(候选人是foo(PinName, PinName)。)

在我放弃并使用const PinName PIN_SD_MISO = p2;之前,有没有人知道一个好的解决方案?

2 个答案:

答案 0 :(得分:1)

我会为此而被击倒,但为什么不仅仅使用宏呢?

#define PIN_SD_MOSI  p0
#define PIN_SD_MISO  p4
#define PIN_SD_SCK   p2
#define PIN_SD_CSN   p6

答案 1 :(得分:0)

有点骇人听闻,但这是我在处理作用域枚举时想到的:

enum class OriginalType {
   FOO,  // 0
   BAR   // 1
   END   // 2
};

enum class ExtendOriginalType : std::underlying_type_t<OriginalType> {
   EXTENDED_FOO = static_cast<std::underlying_type_t<OriginalType>>
                                           (OriginalType::END), // 2
   EXTENDED_BAR  // 3
};

然后使用类似:

OriginalType myOriginalType = (OriginalType)ExtendOriginalType::EXTENDED_BAR;

来自Base enum class inheritance