一、前言
由于C++项目中用了相对比较多的枚举(enum),正常情况下,枚举变量都是占用一个整形类型的大小,但是项目中枚举(enum)只需要使用到一个字节的大小,因为是在嵌入式设备上执行的代码,资源比较少,那么如果枚举都是按照int型大小来使用的话,这无疑是一种资源浪费。
所以就想有没有一种办法可以控制枚举(enum)占用内存的办法。所幸,通过查找资料,发现C++11的新特性刚好加入了控制枚举大小的机制。那么接下来我们就来看看,枚举(enum)在C++11标准有哪些变化?以及C和C++11中的枚举(enum)有什么区别?
二、C中的枚举(enum)
2.1 C中枚举的大小
前面有说到,默认情况下,枚举enum的大小是一个整形类型的大小,但是整形类型有很多:int、long int、short int等,所以enum的大小还是不能确定的。在C中enum的大小是不可以通html" target="_blank">过程序员显式控制的,这个大小是编译器根据我们给枚举(enum)赋值的大小来选择合适的整数类型的。
下面举个例子:
/***************************************************************************** ** Copyright © 2020 lcg. All rights reserved. ** File name: enum.c ** Description: 测试enum的特性 ** Author: lcg ** Version: 1.0 ** Date: 2020.12.08 *****************************************************************************/ #include <stdio.h> enum color1 { RED = 0, GREEN, BLUE }; enum color2 { GRAY = 0x1122334455, YELLOW, PURPLE }; int main(int argc, char *argv[]) { printf("enum color1: %d\n", sizeof(enum color1)); printf("enum color2: %d\n", sizeof(enum color2)); return 0; }
输出结果:
enum color1: 4
enum color2: 8
我们发现这两个枚举变量所占用的大小是不一样的,enum color2已经超过了4个字节,所以编译器会根据实际值的大小来调整枚举变量的大小。
这就存在了一个弊端,当我们定义的一个结构体里面有枚举变量的时候,当枚举变量值变化的时候,那么结构体的大小就有可能会跟着变化。在没有给枚举赋值的时候为结构体申请了堆空间,后面如果给枚举赋了一个超过4个字节的值,那么这个时候结构体的实际大小就已经变化了,这样我们后面程序对该结构体进行操作时就会存在隐患。
2.2 C中枚举的取值范围
我们继续使用上面的例程来说明取值范围:
/***************************************************************************** ** Copyright © 2020 lcg. All rights reserved. ** File name: enum.c ** Description: 测试enum的特性 ** Author: lcg ** Version: 1.1 ** Date: 2020.12.08 *****************************************************************************/ #include <stdio.h> enum color1 { RED = 0, GREEN, BLUE }; enum color2 { GRAY = 1, YELLOW, PURPLE }; int main(int argc, char *argv[]) { enum color1 myClolor1; myClolor1 = RED; printf("myClolor1: %d\n", myClolor1); myClolor1 = GRAY; printf("myClolor1: %d\n", myClolor1); myClolor1 = 10; printf("myClolor1: %d\n", myClolor1); return 0; }
输出结果:
myClolor1: 0
myClolor1: 1
myClolor1: 10
可以看到,在C下enum定义的变量可以赋规定范围外的值的,但是在C++11下这是不允许的。在C++11中编译会不通过,是C++11对C中enum的优化。
三、C++11中的枚举(enum)
3.1 c++11中新增枚举大小的控制
在C++11中程序员就可以对枚举(enum)进行显式控制其占用内存的大小了,如下示例:
/***************************************************************************** ** Copyright © 2020 lcg. All rights reserved. ** File name: enum.cpp ** Description: 测试enum的特性 ** Author: lcg ** Version: 1.2 ** Date: 2020.12.08 *****************************************************************************/ #include <stdio.h> enum color1 : char { RED = 0, GREEN, BLUE }; enum color2 : int { GRAY = 1, YELLOW, PURPLE }; int main(int argc, char *argv[]) { printf("enum color1: %d\n", sizeof(enum color1)); printf("enum color2: %d\n", sizeof(enum color2)); return 0; }
输出结果:
enum color1: 1
enum color2: 4
C++11这样的特性就可以很好地解决我在前言所说的那些情况啦,可以节省资源。
3.2 c++11新增有作用域的枚举类型
如上面2.2小节的程序如果在C++11的标准中编译就会出现以下的报错:
1.cpp:33:15: error: cannot convert ‘color2' to ‘color1' in assignment
myClolor1 = GRAY;
^
1.cpp:36:15: error: invalid conversion from ‘int' to ‘color1' [-fpermissive]
myClolor1 = 10;
在C++11标准中,enum定义的变量是不可以赋规定范围外的值的。这样为后期的调试带来了很多的便利之处。
到此这篇关于C和C++11之enum枚举的具体使用方法的文章就介绍到这了,更多相关C++11 enum枚举内容请搜索小牛知识库以前的文章或继续浏览下面的相关文章希望大家以后多多支持小牛知识库!
本文向大家介绍C++11中std::future的具体使用方法,包括了C++11中std::future的具体使用方法的使用技巧和注意事项,需要的朋友参考一下 C++11中的std::future是一个模板类。std::future提供了一种用于访问异步操作结果的机制。std::future所引用的共享状态不能与任何其它异步返回的对象共享(与std::shared_future相反)( std::
在C语言中,数据类型可分成基本数据类型、构造数据类型、指针数据类型、空类型四大类。本文主要介绍构造数据类型——结构体、共用体。除了这两个之外,还会介绍到枚举。 结构体概述 结构体是一系列具有相同类型或不同类型的数据构成的数据集合,简称结构。在C语言中,可以定义结构体类型,将多个相关的变量包装成一个整体来使用。在结构体中的变量,可以是相同、部分相同或完全不同的数据类型。 结构体类型的定义 结构体
我有一个.Net Core v2.1 Web API,它使用NSwag生成其Swagger Json。 我有一个这样的反应模型- 生成Swagger JSON的- 当在JSON上运行swagger代码时,我在我的IO. Swagger项目中获得了以下LoginResault模型,用于C#(选择了目标框架5.0)- 有人可以帮助描述我如何让枚举生成与IO. Swagger中的原始LoginResul
由于 PHP 本身不支持枚举类型,imi 特别基于注解实现了枚举类。 枚举类定义 继承Imi\Enum\BaseEnum类,然后在类常量上面写上注解@EnumItem,参数是当前常量的文字说明。 <?php namespace ImiDemo\HttpDemo\MainServer\Enum; use Imi\Enum\BaseEnum; use Imi\Enum\Annotation\Enum
问题内容: 我正在学习Java中的Enum,我想知道Java和C ++中Enum的主要区别是什么。谢谢 问题答案: 在C ++中,枚举只是一组命名的整数常量。在Java中,枚举更像是类的命名实例。您可以自定义枚举中可用的成员。 同样,C ++将隐式将枚举值转换为它们的整数等效值,而转换必须在Java中是显式的。 有关更多信息,请参见Wikipedia。
null null null 支持值从不同于零的数字开始 支持负值 支持分段的值 支持(C++11) 支持具有任何允许的(C++11) 编译时(而不是运行时)转换为字符串, 或至少在运行时快速执行(例如不是个好主意……) (C++11,然后在C++14/17/20中放松) (C++11) C++17/C++20友好代码段 一个可能的想法是使用C++编译器的功能,在编译时使用基于和函数的元编程技巧生