C++11的强类型枚举

C++之前的枚举的成员名字是全局可见的,下面的情况就会报错
enum Book1{red = 1, blue = 2, green = 3, black = 4};
enum Book2{red = 1, yellow = 2};
Book1和Book2都含有red,就会出现冲突,C++11枚举解决了这个问题:
enum class Book1{red = 1, blue = 2, green = 3, black = 4};
enum class Book2{red = 1, yellow = 2};

int main() {
	Book1 test = static_cast<Book1>(2);
	switch (test) {
		case Book1::red:
			std::cout << "red" << std::endl;
			break;
		case Book1::blue:
			std::cout << "blue" << std::endl;
			break;
		case Book1::green:
			std::cout << "green" << std::endl;
			break;
		case Book1::black:
			std::cout << "black" << std::endl;
			break;
	}
	return 0;
}
强类型枚举不能和int类型直接转换,必须进行强转!
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++11引入了类型枚举(enum class),也称为枚举类。类型枚举是一种更加类型安全的枚举类型,相对于传统的枚举类型类型枚举可以提供更好的封装性和可读性。 类型枚举的定义方式为: ```cpp enum class EnumName { EnumValue1, EnumValue2, EnumValue3, // ... }; ``` 其中,EnumName 是枚举类型的名称,EnumValue1、EnumValue2、EnumValue3 等是枚举类型的取值。与传统的枚举类型不同的是,类型枚举的取值是不会自动转换为整型的。 例如,下面的代码定义了一个类型枚举: ```cpp enum class Color { RED, GREEN, BLUE }; ``` 由于是类型枚举,因此不能将 Color 型的值直接赋值给整型变量,这样会导致编译错误: ```cpp int i = Color::RED; // 编译错误 ``` 需要使用 static_cast 进行显式转换: ```cpp int i = static_cast<int>(Color::RED); ``` 类型枚举还可以指定底层类型,例如: ```cpp enum class Color : unsigned char { RED, GREEN, BLUE }; ``` 这样,Color 类型的取值实际上是 unsigned char 类型的。 类型枚举的另一个优点是避免了命名冲突。例如,传统的枚举类型可能会出现以下情况: ```cpp enum Color { RED, GREEN, BLUE }; enum Size { SMALL, MEDIUM, LARGE }; ``` 如果要定义一个红色小尺寸的物品,可能会这样写: ```cpp Color c = RED; Size s = SMALL; ``` 但是,由于 RED 和 SMALL 都是 int 类型的 0,因此这样的代码会出现命名冲突。使用类型枚举可以避免这种情况的发生: ```cpp enum class Color { RED, GREEN, BLUE }; enum class Size { SMALL, MEDIUM, LARGE }; Color c = Color::RED; Size s = Size::SMALL; ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值