假设我在另一个无法更改的库中有以下代码 :
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 {
但是别名从不在范围内 - 我怀疑我必须使用普通enum
。 enum : 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;
之前,有没有人知道一个好的解决方案?
答案 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;