枚举标记超过 2^32

本文关键字:枚举 | 更新日期: 2023-09-27 18:33:01

我在应用程序中使用枚举标志。枚举可以有大约 50+ 个值,因此值最多为 2^50。我只是想知道,我可以用Math.Pow(2, variable)来计算这些吗?

当我尝试这样做时,我得到一个常量值编译时错误。除了手动计算 2 的这些幂并将其放入之外,还有其他方法吗?

这是我正在做的:

[Flags]
internal enum RiskStates : long
    {
        None = 0,
        AL = Convert.ToInt64(Math.Pow(2,0)),
        AK = 2,
        AZ = 4,
        AR = 8,
        CA = 16,
        CO = 32,
        CT = 64,
        DC = 128,
        DE = 256,
        FL = 512,
        GA = 1024,
        HI = 2048,
        ID = 4096,
        IL = 8192,
        IN = 16384,
        IA = 32768,
        KS = 65536,
        KY = 131072,
        LA = 262144,
        ME = 524288,
        MD = 1048576,
        MA = 2097152,
        MI = 4194304
}

枚举标记超过 2^32

当我尝试这样做时,我得到一个常量值编译时错误。

如果您使用 L 后缀强制它成为long文字,您实际上没问题 - 但必须手动指定它们仍然不理想。(在阅读代码时,这不是"明显正确的"。

您不能使用 Math.Pow,因为表达式必须是编译时常量 - 但您可以使用位移:

None = 0,
AL = 1L << 0,
AK = 1L << 1,
AZ = 1L << 2

等。无论如何,我认为这更具可读性:)

如果您更改为使用非十进制表示法,其中 2 的幂更规则,那么您将不再需要自动生成它们,例如:

// octal
AL = 0001L,
AK = 0002L,
AZ = 0004L,
AR = 0010L,
CA = 0020L,
CO = 0040L,
CT = 0100L,
...
// hexadecimal
AL = 0x001L,
AK = 0x002L,
AZ = 0x004L,
AR = 0x008L,
CA = 0x010L,
CO = 0x020L,
CT = 0x040L,
...

我很想考虑使用 BitArray 作为底层结构。