C++11中新引入的enum类型

2024-09-07 01:44
文章标签 c++ 类型 引入 enum 中新

本文主要是介绍C++11中新引入的enum类型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、引言

        在C++11中,引入了一个新的枚举类型——enum class(或称为作用域枚举类型),它相较于传统的enum类型有几个关键的不同点。enum class提供了更强的类型检查和封装,减少了命名冲突的可能性,并允许更加清晰地表达枚举的意图。

二、传统枚举(enum)的缺点

        在C++11之前,枚举(enum)类型是隐式转换为整型的,这可能会导致一些意料之外的类型安全问题。此外,传统枚举的作用域是从声明点到声明该枚举的文件末尾,这可能会导致在不同上下文中名称的冲突。

enum LightColor{RED, GREEN, YELLOW
};enum ClothesColor{RED, GREEN, YELLOW    // 此处会报重复声明的错误,因为LightColor枚举中已经声明了RED等
};int main(){LightColor color1 = RED;ClothesColor color2 = RED;
}

以上代码会有编译错误,因为LightColor中声明了RED,而在ClothesColor中又声明了RED,因此两者冲突。

三、在C++11中避免此冲突

enum class LightColor{RED, GREEN, YELLOW
};enum class ClothesColor{RED, GREEN, YELLOW
};int main(){// 在枚举值前加上类型的限定符,表明枚举值是哪个类型的值// 这样就可以避免产生冲突了LightColor color1 = LightColor::RED;ClothesColor color2 = ClothesColor::RED;
}

四、enum class的优点

  • 作用域限定:enum class的成员仅在枚举本身的作用域内可见,需要使用枚举类型名作为前缀来访问其成员,这减少了命名冲突的可能性。
  • 不隐式转换为整型:enum class类型的值不会自动转换为整型(如int),除非显式进行类型转换。这提高了类型安全性。
  • 更好的命名空间支持:enum class可以在更复杂的命名空间中声明,使得枚举的使用更加灵活和清晰。
  • 允许指定底层类型:通过: 底层类型语法,enum class可以指定其底层数据类型(如int、char等),以控制枚举值的存储和表示。
#include <cstdint>// 指定LightColor的底层使用int8_t整数类型
enum class LightColor: int8_t{RED = -1, GREEN = 0, YELLOW = 8
};

五、示例

#include <iostream>  // 定义一个enum class  
enum class Color {  RED, GREEN, BLUE  
};  int main() {  // 枚举类型的变量声明  Color myColor = Color::RED;  // 正确使用枚举类型  if (myColor == Color::RED) {  std::cout << "The color is red." << std::endl;  }  // 错误用法:没有前缀Color::会导致编译错误  // if (myColor == RED) { // 错误  // 显示转换为整型(如果需要)  int colorValue = static_cast<int>(myColor);  // 注意:不同的枚举值可以有不同的底层值  enum class Status : char {  OK = 'a',  ERROR = 'b'  };  Status status = Status::OK;  char statusChar = static_cast<char>(status);  return 0;  
}

六、小结

        enum class是C++11引入的一种新的枚举类型,它通过提供作用域限定、避免隐式类型转换以及允许指定底层类型等方式,改进了传统枚举类型(enum)的使用。这使得enum class成为C++11及更高版本中推荐使用的枚举类型。

附:c++11新增的其他性

这篇关于C++11中新引入的enum类型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1143705

相关文章

C++ move 的作用详解及陷阱最佳实践

《C++move的作用详解及陷阱最佳实践》文章详细介绍了C++中的`std::move`函数的作用,包括为什么需要它、它的本质、典型使用场景、以及一些常见陷阱和最佳实践,感兴趣的朋友跟随小编一起看... 目录C++ move 的作用详解一、一句话总结二、为什么需要 move?C++98/03 的痛点⚡C++

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

C++构造函数中explicit详解

《C++构造函数中explicit详解》explicit关键字用于修饰单参数构造函数或可以看作单参数的构造函数,阻止编译器进行隐式类型转换或拷贝初始化,本文就来介绍explicit的使用,感兴趣的可以... 目录1. 什么是explicit2. 隐式转换的问题3.explicit的使用示例基本用法多参数构造

C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解

《C++,C#,Rust,Go,Java,Python,JavaScript的性能对比全面讲解》:本文主要介绍C++,C#,Rust,Go,Java,Python,JavaScript性能对比全面... 目录编程语言性能对比、核心优势与最佳使用场景性能对比表格C++C#RustGoJavapythonjav

MyBatis中的两种参数传递类型详解(示例代码)

《MyBatis中的两种参数传递类型详解(示例代码)》文章介绍了MyBatis中传递多个参数的两种方式,使用Map和使用@Param注解或封装POJO,Map方式适用于动态、不固定的参数,但可读性和安... 目录✅ android方式一:使用Map<String, Object>✅ 方式二:使用@Param

C++打印 vector的几种方法小结

《C++打印vector的几种方法小结》本文介绍了C++中遍历vector的几种方法,包括使用迭代器、auto关键字、typedef、计数器以及C++11引入的范围基础循环,具有一定的参考价值,感兴... 目录1. 使用迭代器2. 使用 auto (C++11) / typedef / type alias

C# WebAPI的几种返回类型方式

《C#WebAPI的几种返回类型方式》本文主要介绍了C#WebAPI的几种返回类型方式,包括直接返回指定类型、返回IActionResult实例和返回ActionResult,文中通过示例代码介绍的... 目录创建 Controller 和 Model 类在 Action 中返回 指定类型在 Action

C++ scoped_ptr 和 unique_ptr对比分析

《C++scoped_ptr和unique_ptr对比分析》本文介绍了C++中的`scoped_ptr`和`unique_ptr`,详细比较了它们的特性、使用场景以及现代C++推荐的使用`uni... 目录1. scoped_ptr基本特性主要特点2. unique_ptr基本用法3. 主要区别对比4. u

C++11中的包装器实战案例

《C++11中的包装器实战案例》本文给大家介绍C++11中的包装器实战案例,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录引言1.std::function1.1.什么是std::function1.2.核心用法1.2.1.包装普通函数1.2.

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js