多个枚举
Multiple enumerations
本文关键字:枚举 更新时间:2023-10-16
我想知道我是否可以在已经存在的同一文件中使用不同的枚举?
对于这个项目,我有一些元素可以作为许多书籍的类型。我想为这些书创建不同的故事,并为它们创建一个第二个枚举。
enum element {
ICE, FIRE, EARTH, WIND, NONE
};
enum book stories {
FK, IK, EK, WK, NONE
};
这会让我的编译器出现问题吗?
是的。枚举NONE
存在于element
和book stories
中(顺便说一句,您不能用空格命名枚举)。
枚举类
如果要在两个枚举中使用NONE
,请使用 enum class
es。
enum class element
{
ICE, FIRE, EARTH, WIND, NONE
};
enum class bookstories
{
FK, IK, EK, WK, NONE
};
然后像这样使用枚举:
auto elem = element::NONE;
auto story = bookstories::NONE;
撇开book stories
引起的语法错误不谈,您可以通过将它们放入作用域来使enum
声明明确:
struct Elements {
enum element {
ICE, FIRE, EARTH, WIND, NONE
};
};
struct BookStories {
enum book_stories {
FK, IK, EK, WK, NONE
};
};
那么提到Elements::NONE
和BookStories::NONE
将是明确的。
使枚举作用域化的另一种方法是使用 enum class
(从 c++11 开始):
enum class element {
ICE, FIRE, EARTH, WIND, NONE
};
enum class book_stories {
FK, IK, EK, WK, NONE
};
这通常通过这样做来解决:
typedef enum element_e {
E_ELEMENT_ERROR = -1,
E_ELEMENT_NONE,
/* ... */
} element_t;
typedef enum bookstories_e {
E_BOOKSTORIES_ERROR = -1,
E_BOOKSTORIES_NONE,
/* ... */
} bookstories_t;
因此,您可以在头文件中维护C/C++互操作。如果您没有任何 C 模块,请使用枚举类,如其他答案所述。
相关文章:
- 不带大括号的枚举形式
- 枚举环境变量的惯用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++ 中输出枚举类类型的向量元素