Nat*_*man 4 c++ enums type-conversion
在我正在重写的内部的C++库中,我有一些无符号整数变量,我想将其转换为枚举:
enum InitType {
INIT,
NON_INIT
};
Run Code Online (Sandbox Code Playgroud)
我有一个这种类型的变量:
InitType InitVar;
Run Code Online (Sandbox Code Playgroud)
该库是从其变量为普通整数的代码的另一部分调用的:
uint32_t UnsignedIntVar;
Run Code Online (Sandbox Code Playgroud)
我想将从调用者传递的无符号版本分配给库内部枚举:
InitVar = UnsignedIntVar;
Run Code Online (Sandbox Code Playgroud)
但编译器不喜欢这样:
error: invalid conversion from 'uint32_t' to 'InitType'
Run Code Online (Sandbox Code Playgroud)
执行此转换的最简洁方法是什么?
以下是我的一些想法:
如果enum只有两个值,我可以这样做:
InitVar = UnsignedIntVar ? Init : NonInit;
Run Code Online (Sandbox Code Playgroud)
这是我想做这样一个任务的时候写的很多东西.
如果它有更多值,我可以创建一个转换表:
InitType Uint2InitTypeConv = {INIT_0, INIT_1, INIT_2...};
Run Code Online (Sandbox Code Playgroud)
哪里INIT_x只是枚举的名称.然后我可以使用表格进行翻译:
InitVar = Uint2InitTypeConv[UnsignedIntVar];
Run Code Online (Sandbox Code Playgroud)
这看起来很干净.但是,我认为我应该可以为此重载operator=,但我似乎无法做到这一点.这很容易包含我能提出的任何其他丑陋.
Ker*_* SB 13
您可以显式转换为枚举:
InitType i = InitType(UnsignedIntvar);
Run Code Online (Sandbox Code Playgroud)
如果整数没有与已知枚举值对应的值,那么这就是您的问题.
这是完全可以接受的典型情况是循环枚举:
enum ESomething { Default = 0, Something, SomeOtherThing };
for (int i = 0; i != 3; ++i)
{
ESomething e = ESomething(i);
// do something with "e"
}
Run Code Online (Sandbox Code Playgroud)