带位的长枚举

Long enum with bitwise

本文关键字:枚举      更新时间:2023-10-16

在通过第32个标志后,我的enum一直面临问题

enum ConditionType_t {
    CONDITION_NONE                          = 0,
    CONDITION_LIGHT                         = 1 << 0,
    CONDITION_INFIGHT                       = 1 << 1,
    CONDITION_MUTED                         = 1 << 2,
    ...
    CONDITION_LUCKY                         = 1 << 32,
}

知道enums基本上是8bitCONDITION_LUCKY将等于CONDITION_NONE。所以我实现了C++11enum classes:

enum class ConditionType_t : uint64_t {
    CONDITION_NONE                          = 0,
    CONDITION_LIGHT                         = 1 << 0,
    CONDITION_INFIGHT                       = 1 << 1,
    CONDITION_MUTED                         = 1 << 2,
    ...
    CONDITION_LUCKY                         = 1 << 32,
}

现在我收到了数百万条警告,比如:

warning C4293: '<<' : shift count negative or too big, undefined behavior

错误如:

error C2065: 'CONDITION_NONE' : undeclared identifier

显然,比特移位与enum classes不兼容。

有什么想法吗?

表达式1 << 32是未定义的行为。来自[expr.shift]:

如果右操作数为负数,或大于或等于提升后的左操作数的位长度。

由于1int,所以它只有32位。即使这不是未定义的,你也不会得到你想要的值,因为1 << 32的类型是int,它无论如何都不能容纳33位的值。

您需要从一开始就使用uint64_t

enum class ConditionType_t : uint64_t {
    CONDITION_NONE                          = 0,
    CONDITION_LIGHT                         = 1ULL << 0,
    CONDITION_INFIGHT                       = 1ULL << 1,
    CONDITION_MUTED                         = 1ULL << 2,
    ...
    CONDITION_LUCKY                         = 1ULL << 32,
};