C++之枚举类

1. 枚举类定义

语法形式

enum class 枚举类型名: 底层类型 {枚举值列表}; 

如果不指定底层类型,默认为int

例:

enum class Type { General, Light, Medium, Heavy};
enum class Type: char { General, Light, Medium, Heavy};
enum class Category { General=1, Pistol, MachineGun, Cannon};
2.枚举类的优势

2.1 强作用域,其作用域限制在枚举类中:

例: 使用Type的枚举值General: Type::General

2.2 转换限制,枚举类对象不可以与整型隐式地互相转换。

2.3 可以指定底层类型

例: enum class Type: char { General, Light, Medium, Heavy};

枚举类举例:

#include<iostream>
using namespace std;
enum class Side{ Right, Left };   
enum class Thing{ Wrong, Right };  //都有Right,但是不冲突

int main()
{
	Side s = Side::Right;
	Thing w = Thing::Wrong;
	cout << (s == w) << endl;  //尽管s和w都是整型,但编译错误,因为无法直接比较不同枚举类
	return 0;
}
<think>我们首先需要明确:C++中的枚举类enum class)是强类型枚举,不能直接使用整数迭代。但可以通过一些技巧实现遍历,例如使用模板元编程或预定义范围。 常见方法: 1. 使用辅助数组(适用于已知枚举值范围且连续的情况) 2. 通过反射宏(需要预定义枚举的取值) 3. C++17的std::underlying_type配合模板 以下是一个使用辅助数组的示例(假设枚举值连续): ```cpp #include <iostream> #include <array> // 定义枚举类 enum class Color { Red, Green, Blue, Count }; // Count表示枚举值的数量 int main() { // 遍历枚举值(注意:不包括Count) for (int i = 0; i < static_cast<int>(Color::Count); ++i) { Color c = static_cast<Color>(i); // 使用c std::cout << i << std::endl; } return 0; } ``` 如果枚举值不连续,可以手动创建一个数组存储所有枚举值,然后遍历该数组: ```cpp #include <iostream> #include <vector> enum class Status { Stopped = 5, Running = 10, Error = -1 }; int main() { const std::vector<Status> all_statuses = { Status::Stopped, Status::Running, Status::Error }; for (const auto& s : all_statuses) { // 使用s std::cout << static_cast<int>(s) << std::endl; } return 0; } ``` 使用C++17的模板函数(需要枚举值从0开始连续): ```cpp #include <iostream> #include <type_traits> enum class Fruit { Apple, Banana, Orange, Count }; template <typename E> constexpr auto to_underlying(E e) noexcept { return static_cast<std::underlying_type_t<E>>(e); } int main() { for (int i = 0; i < to_underlying(Fruit::Count); ++i) { Fruit f = static_cast<Fruit>(i); // 使用f std::cout << i << std::endl; } return 0; } ``` 注意:枚举类遍历没有内置支持,以上方法均需额外处理。 §§相关问题§§ 1. 如何遍历非连续取值的C++枚举类? 2. 在C++11及以上版本中,有哪些安全的枚举遍历方法? 3. 如何避免在遍历枚举类时引入魔法数字(magic numbers)? 4. 使用模板元编程实现枚举遍历时需要注意哪些陷阱? 5. 有没有第三方库(如boost)提供对枚举类遍历的更好支持?</think>### 回答 在C++中遍历枚举类(`enum class`)需要特殊处理,因为枚举类是强类型且不会隐式转换为整数。以下是三种常用方法: #### 方法1:使用辅助数组(推荐) ```cpp #include <iostream> #include <array> enum class Color { Red = 1, Green = 2, Blue = 4 }; int main() { // 创建枚举值数组 constexpr std::array colors = { Color::Red, Color::Green, Color::Blue }; // 遍历数组 for (auto color : colors) { switch(color) { case Color::Red: std::cout << "Red\n"; break; case Color::Green: std::cout << "Green\n"; break; case Color::Blue: std::cout << "Blue\n"; break; } } } ``` #### 方法2:使用整数强制转换 ```cpp #include <iostream> #include <type_traits> enum class Status { Stopped = 0, Running = 1, Error = 2 }; int main() { // 获取枚举范围 constexpr int min_val = 0; constexpr int max_val = 2; // 遍历整数范围并转换 for (int i = min_val; i <= max_val; ++i) { auto status = static_cast<Status>(i); std::cout << static_cast<int>(status) << " "; // 输出:0 1 2 } } ``` #### 方法3:使用模板元编程(C++17) ```cpp #include <iostream> enum class Direction { North, South, East, West }; template <Direction... Ds> void print_directions(std::integer_sequence<Direction, Ds...>) { ((std::cout << static_cast<int>(Ds) << " "), ...); // 输出:0 1 2 3 } int main() { print_directions(std::integer_sequence< Direction, Direction::North, Direction::South, Direction::East, Direction::West>{}); } ``` > **注意事项**: > 1. 枚举类不会自动提供迭代器或范围信息 > 2. 方法2仅适用于连续取值的枚举 > 3. 推荐使用方法1,代码可读性最好 > 4. C++23的`std::to_underlying`可替代`static_cast`
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值