初始化枚举c++
Initialize enum c++
我创建了一个名为Types
:的枚举
enum Types {Int,Double,String};
当我创建一个对象并用枚举允许的值之一初始化它时,我会得到以下错误:"错误:类型名称不允许"。
Types ty = Types.Double;
有什么想法吗?
在C++中,有两种不同类型的枚举-作用域枚举和非作用域枚举(前者是在C++11中引入的)。对于无范围的枚举器,枚举器的名称直接引入到封闭范围中。
N3337§7.2/10
在立即包含枚举说明符的作用域。每个作用域枚举器是在枚举的作用域中声明的。这些名称遵循(3.3)和(3.4)中为所有名称定义的范围规则。
您的枚举没有范围,因此编写就足够了
Types ty = Double;
对于作用域枚举,顾名思义,枚举器是在枚举作用域中声明的,并且必须使用枚举名称进行限定:
enum class ScopedTypes {Int,Double,String};
enum UnscopedTypes {Int,Double,String};
ScopedTypes a = ScopedTypes::Double;
//ScopedTypes b = Double; // error
UnscopedTypes c = UnscopedTypes::Double;
UnscopedTypes d = Double;
使用
Types ty = Double;
或
enum class Types {Int,Double,String};
Types ty = Types::Double;
编译器抱怨试图限定值Double
,这是Java的方法。
只做
Types ty = Double;
相关文章:
- 不带大括号的枚举形式
- 枚举环境变量的惯用C++14/C++17方法
- 类似枚举的计算常量
- 如何正确实现和访问运算符的各种自定义枚举器
- 错误:从"int"到枚举c++的转换无效
- C++中构造函数中的枚举
- 访问在 C++ 结构中声明的枚举变量
- 枚举类'classname'的多重定义
- 强枚举类型定义:Clang Bug 还是 C++11 标准不确定性?
- typedef 枚举和枚举类有什么区别?
- 为什么我的开关/机箱在使用枚举时默认?
- 标准::可选枚举的比较运算符
- C++两个源文件之间共享的枚举的静态实例
- 打印没有铸件的枚举可以在C++中吗?
- 枚举成员与静态 int 成员?
- C++:枚举:错误:应使用标识符而不是"}"
- 带有 c++ 的枚举(输入检查)
- 在 qml 中使用 Q_ENUM 和 Q_PROPERTY 作为枚举类
- 为什么 int 类型的枚举类值不能用作 int
- 在 C++ 中输出枚举类类型的向量元素