C++ 中的枚举中的数组

Arrays in enums in C++

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

目前我的C++代码是:

constexpr struct my_codes {
    std::array<int, other_class1::static_constans1> num1 = {{0, 1, 2, 3, 4, 5, 6}};
    std::array<int, other_class2::staric_constans2> num2 = {{7, 8, 9, 10, 11, 12, 13, 14}};
    int num3 = 15;
} my_codes;

显然我对此感觉很糟糕,而且它正在失控(我打出了前 100 个数字)。可悲的是,这些枚举是非法的:

enum my_codes {
    num1[other_class1::static_constans1], 
    num2[other_class2::staric_constans2], 
    num3
};
enum my_codes {num1[7], num2[8], num3};

我可以通过某种魔法在枚举中拥有数组吗?我可以使用任何宏吗?一些递归模板?

编辑:我会像这样使用它:

enum my_codes {num1[7], num2[8], num[3]};
if (some_int == my_codes::num2[3]) do_somethig();

枚举将具有以下值:

my_codes::num1[0] == 0
my_codes::num1[1] == 1
...
my_codes::num1[6] == 6
my_codes::num2[0] == 7
my_codes::num2[1] == 8
...
my_codes::num2[7] == 14
my_codes::num3    == 15

由于常量是连续的,因此不需要数组 - 范围检查操作就足够了。也就是说,由于num1包含[0, 7)num2包含[7, 15),因此您的结构可以表示为

 constexpr struct my_codes {
     std::array<int,4> num = {{0,7,14,15}}
 } mycodes;
 constexpr int getIndex(int i, int offset = 0) {
    return (offset==3 || i < mycodes.num[offset+1]) ?
    offset :
    getIndex(i, offset+1) ;
 }

这只是通过constexpr数组编写线性搜索的一种递归方式。生成第 i 个范围更简单,只需num[i]num[i+1] .