我有一个第三方无范围的枚举(我无法修改),我真的很想投射到我自己的范围内。我怎样才能提供像转换运算符这样的东西?
我想做的是这样的事情:
#include <iostream>
enum ThirdPartyLetter {
A=4,
B=5
};
enum class MyNumber {
ONE=1,
TWO=2
// This doesn't compile, of course
/*Number(const ThirdPartyLetter& rhs) {
if(rhs == ThirdPartyLetter::A) {
return ONE;
}
else {
return TWO;
}
}*/
};
int main() {
ThirdPartyLetter letter = ThirdPartyLetter::A;
MyNumber number = static_cast<MyNumber>(letter);
// Without the cast, this prints 4 (an invalid enum value!)
std::cout << int(number) << std::endl;
}
有没有办法提供从ThirdPartyNumber
到MyNumber
的某种演员?
答案 0 :(得分:8)
在C ++编译时这样做的惯用方法是使用特征 举个例子:
enum Foo { ONE, TWO };
enum Bar { THREE, FOUR };
template<Foo> struct conv;
template<> struct conv<Foo::ONE> { static constexpr Bar value = Bar::THREE; };
template<> struct conv<Foo::TWO> { static constexpr Bar value = Bar::FOUR; };
如果你想在运行时这样做,也许开关很适合 无论如何,您仍然可以使用特征来集中转换逻辑并执行以下操作:
Bar get(Foo choice) {
switch(choice) {
case Foo::ONE:
return conv<ONE>::value;
case Foo::TWO:
return conv<TWO>::value;
}
}