iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >关于C++11中限定作用域的枚举类型的问题
  • 112
分享到

关于C++11中限定作用域的枚举类型的问题

2024-04-02 19:04:59 112人浏览 薄情痞子
摘要

枚举类型是将一组有限的整数常量组织在一起用以描述变量可取值范围的一种数据类型。c++中有两种类型的枚举:不限定作用域的枚举类型和限定作用域的枚举类型。限定作用域的枚举类型是C++11

枚举类型是将一组有限的整数常量组织在一起用以描述变量可取值范围的一种数据类型。c++中有两种类型的枚举:不限定作用域的枚举类型和限定作用域的枚举类型。限定作用域的枚举类型是C++11标准引入的新类型。

● 限定作用域枚举类型是为了弥补不限定作用域枚举类型的不足而出现的,不限定作用域的枚举类型不是类型安全的,主要表现在如下几个方面:

● 不限定作用域的枚举类型中的枚举成员被视为整数,两种不同的枚举类型之间可以进行比较。两种不同类型的数据进行比较,可能带来数据类型转换,引起数据表示不完整。

● 不限定作用域枚举所使用的整数类型及其大小都由实现方法定义,皆无法明确指定。

● 不限定作用域枚举类型的枚举成员与枚举类型外部数据处在同一个作用域范围内,多个枚举类型不能有同名的枚举成员。

C++11标准引入的限定作用域的枚举类型,其定义方式如下所示:

enum class 枚举类型名称 {枚举成员1, 枚举成员2, …, 枚举成员n};

相对于不限定作用域的枚举类型,限定作用域的枚举类型定义的枚举成员在枚举类型作用域外不可访问。

//定义不限定作用域枚举类型
enum color {red, yellow, green};  
//错误,不限定作用域枚举成员不能与其它枚举类型成员同名
enum stoplight{red, yellow, green}; 

//正确,限定作用域枚举成员的作用域限定在类型内
enum class newcolor {red, yellow, green}; 
//正确,不限定作用域的枚举类型外可以使用枚举成员
color e_color = green;       
//错误,限定作用域的枚举成员在类型外不可访问
//虽然color类型的green成员可访问,但是color与newcolor类型不同,不可赋值
newcolor ec_color = green;   

在旧标准中,枚举变量可以使用整数常量进行赋值,但在C++11标准中,要想初始化枚举类型对象或对枚举对象赋值,必须使用该类型的一个枚举成员或该类型的一个对象。示例代码如下所示:


enum color {red, yellow, green};  
enum class newcolor {red, yellow, green};  

color e_var1 = 1;                 //错误,1不是枚举类型值
color e_var2 = red;                //正确,red是color类型的枚举值
color e_var3 = e_var2;             //正确,同类型数据之间的赋值
newcolor e_nvar1 = newcolor::red;       //正确,red是newcolor类型的枚举值

不限定作用域的枚举类型对象或枚举成员可以自动转化为整型,因此可以在需要整数的地方使用它们,限定作用域的枚举类型却没有此特点。示例代码如下所示:

int i = color::red;               //正确,不限定作用域的枚举成员可转化为整数
int j = newcolor::red;             //错误,限定作用域的枚举成员不可转化为整数

C++11新标准除了增加了限定作用域枚举类型外,还改进了原有的不限定作用域枚举类型的定义形式:

1、枚举类型中枚举成员的类型可以显式指定,指定方式是在枚举类型名称后加冒号和枚举成员类型。

enum intvalues:unsigned long long{
  chartype = 255, shorttype = 65535, inttype = 4295967295,
  longtype = 4294967295ul,
  longlongtype = 18446744073709551615ul
};

若不指定枚举成员类型,限定作用域枚举类型成员默认为int,不限定作用域枚举类型成员不存在默认类型,能够确定的是成员类型足够大到能容纳所有成员。指定了枚举成员类型后,若某一枚举成员值超出了该类型所能容纳的范围,将引发错误。

2、在C++11 中,可以提前声明enum。enum的前置声明必须指定枚举成员类型,隐式指定或显式指定均可。

enum etype1;              //错误,不限定作用域枚举类型的前置声明应指定成员类型
enum etype2:unsigned int;      //正确
enum class etype3;          //正确,限定作用域枚举类型成员有默认类型int 
enum class etype4:unsigned int;  //正确,前置声明指定枚举成员类型

与所有的声明语句一样,枚举的声明和定义中描述的成员类型必须一致,另外不能在同一个上下文中先声明一个不限定作用域的枚举类型再声明一个同名的限定作用域枚举类型。

enmu class Clolor:char; //前置声明枚举类
void Foo(Color*p); //前置声明的使用
//....................
enum class Color:char{RED,GREEN,BLACK,WHITE}; //前置声明的定义

参考链接:

C++11强类型枚举——枚举类

限定作用域的枚举类型 - C语言学习教程_C语言程序_ c语言编程_ c语言入门

到此这篇关于C++11:限定作用域的枚举类型的文章就介绍到这了,更多相关C++11作用域枚举类型内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: 关于C++11中限定作用域的枚举类型的问题

本文链接: https://www.lsjlt.com/news/163968.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 关于C++11中限定作用域的枚举类型的问题
    枚举类型是将一组有限的整数常量组织在一起用以描述变量可取值范围的一种数据类型。C++中有两种类型的枚举:不限定作用域的枚举类型和限定作用域的枚举类型。限定作用域的枚举类型是C++11...
    99+
    2022-11-13
  • C++11中强类型枚举的使用
    目录1.C/C++98中的枚举的缺陷2.强类型枚举的使用1.C/C++98中的枚举的缺陷 枚举在C语言中是狠古老的类型,它分为匿名枚举和具名枚举,如果是匿名枚举,那么它的用法只有一种...
    99+
    2023-02-02
    C++11 强类型枚举
  • C#中的枚举类型怎么定义使用
    这篇文章主要介绍“C#中的枚举类型怎么定义使用”,在日常操作中,相信很多人在C#中的枚举类型怎么定义使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C#中的枚举类型怎么定义使用”的疑惑有所帮助!接下来,请跟...
    99+
    2023-07-02
  • 如何使用C#中的Enum.GetNames函数获取枚举类型中所有定义的名称
    在C#中,枚举类型是一种非常有用的数据类型,它允许我们定义一些常量来表示某些状态或选项。一旦定义了枚举类型,就可以使用Enum.GetNames函数来获取所有定义的名称。本文将详细介绍如何使用该函数,并提供具体的代码示例。什么是Enum.G...
    99+
    2023-11-18
    C# enum GetNames
  • 关于JS中的作用域中的问题思考分享
    目录作用域全局作用域作用域中的错误局部作用域with弊端数据泄露性能下降letconst作用域链闭包闭包对作用域链的影响匿名函数的赋值使用let作用域 作用域,也就是我们常说的词法作...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作