为什么不能将作用域枚举隐式转换为 int?如果我有
enum class Foo:uint32_t{...};
然后我知道 Foo 涵盖的整数是 uint32_t 涵盖的整数的子集,所以我应该始终是安全的。我在这里错过了一些怪癖吗?但相反的做法并不安全。
最佳答案
正如 LightnessRacesinOrbit 在他的 answer 中解释的那样,作用域枚举的全部目的是禁止隐式转换为基础类型。
您可以通过 static_cast
显式转换它们,但是如果您想要指定底层类型的能力,同时允许隐式转换,您也可以使用常规枚举来实现,只需删除class
定义的关键字。
enum class Foo1 : uint32_t{ THING };
enum /*class*/ Foo2 : uint32_t{ THING };
uint32_t conv1 = static_cast<uint32_t>(Foo1::THING);
uint32_t conv2 = Foo2::THING; // <-- implicit conversion!
关于c++ - 将作用域枚举转换为 int,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23549280/