枚举标记超过 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
}
当我尝试这样做时,我得到一个常量值编译时错误。
如果您使用 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 作为底层结构。