c++ - 将作用域枚举转换为 int

标签 c++ c++11 type-safety

为什么不能将作用域枚举隐式转换为 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/

相关文章:

c++ - 如何使用gl_polygon绘制3d圆柱体

c++ - 嵌入式 Linux 中链接 'libstdc++' 库已损坏

c++ - 如何防止 C++ 中的舍入错误?

c++ - 从 char* move std::string 的构造函数

Java数据库字符串类型和类型安全

c++ - 可变参数模板类的可变参数模板

c++ - 如何编写特征转换以将 'const' 添加到类型*

c++ - 可变参数模板类的部分特化是否应该支持非可变参数特化

c++ - 在 static_cast 之后执行类型安全检查的任何方法?

c# - 如何使数据绑定(bind)类型安全并支持重构?