C语言enum关键字

C语言enum关键字

很多初学者对枚举(enum)感到迷惑,或者认为没什么用,其实枚举(enum)是个很有用的数据类型。

一、枚举类型的使用方法

一般的定义方式如下:
enum enum_type_name
{
ENUM_CONST_1,
ENUM_CONST_2,
...
ENUM_CONST_n
} enum_variable_name;


注意:enum_type_name 是自定义的一种数据数据类型名,而enum_variable_name 为enum_type_name类型的一个变量,也就是我们平时常说的枚举变量。实际上enum_type_name类型是对一个变量取值范围的限定,而花括号内是它的取值范围,即enum_type_name 类型的变量enum_variable_name 只能取值为花括号内的任何一个值,如果赋给该类型变量的值不在列表中,则会报错或者警告。ENUM_CONST_1、ENUM_CONST_2、...、ENUM_CONST_n,这些成员都是常量,也就是我们平时所说的枚举常量(常量一般用大写)。

enum 变量类型还可以给其中的常量符号赋值,如果不赋值则会从被赋初值的那个常量开始依次加1,如果都没有赋值,它们的值从0 开始依次递增1。

如分别用一个常数表示不同颜色:

enum Color
{
GREEN = 1, //1
RED,//2
BLUE,//3
GREEN_RED = 10,//10
GREEN_BLUE //11
}ColorVal;


其中各常量名代表的数值分别为:
GREEN = 1
RED = 2
BLUE = 3
GREEN_RED = 10
GREEN_BLUE = 11

举个例子说明一下吧,便于理解

#include <iostream> 
using namespace std; 

void main(void) 
{ 
	enum egg {a,b,c}; 
	enum egg test; //在这里你可以简写成egg test; 
	test = c; 
	if (test==c) 
	{ 
		cout <<"枚举变量判断:test枚举对应的枚举元素是c" << endl; 
	} 
	
	if (test==2) 
	{ 
		cout <<"枚举变量判断:test枚举元素的值是2" << endl; 
	} 
	cout << a << "|" << b << "|" << test <<endl; 
	test = (enum egg) 0; //强制类型转换 
	cout << "枚举变量test值改变为:" << test <<endl; 
	cin.get(); 
}

二、枚举与#define 宏的区别
下面再看看枚举与#define 宏的区别:
1)#define 宏常量是在预编译阶段进行简单替换。枚举常量则是在编译的时候确定其值。
2)一般在编译器里,可以调试枚举常量,但是不能调试宏常量。
3)枚举可以一次定义大量相关的常量,而#define 宏一次只能定义一个。

sizeof(ColorVal)的值为多少?为什么?

下面是我看到的一个很好的东西,讨论组里的,很不错,高手不少啊,O(∩_∩)O~

大家也来测试一下自己的水平怎么样吧,看看下面这个例子,给个结果吧

typedef struct weekday_st
{
    enum week  {sun=123456789,mon,tue,wed,thu,fri,sat,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,ab,ac,ad,ae,af,ag,ah,ai,aj,ak};
    enum day{monring, moon, aftermoon};
}weekday_st;

int main(int argc, char *argv[])
{
    printf("sizeof(weekday_st)=%d\n", sizeof(weekday_st));
    printf("sizeof(weekday)=%d\n", sizeof(weekday_st::week));
    printf("sizeof(day)=%d\n", sizeof(weekday_st::day));
    return 0;
}

结果如下,你答对了吗?O(∩_∩)O~

sizeof(weekday_st)=1
sizeof(weekday)=4
sizeof(day)=4

具体来说一下为什么吧?

printf("sizeof(weekday_st)=%d\n", sizeof(weekday_st));
这里因为结构体里面并没有定义任何的变量,其实只是两个类型(内嵌“类型”)而已,所以这个结构是空的,但是用sizeof进行运算的话也不能返回0,因为毕竟存在着这么一个东西,所以这时sizeof返回一个在机器里面所能表达的最小的存储单位的值,一般的PC里面最小的存储单位的值是char,所以sizeof返回1,你可以试着改变一下上面的实例如下:

typedef struct weekday_st
{
    enum week{sun=123456789,mon,tue,wed,thu,fri,sat,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z,aa,ab,ac,ad,ae,af,ag,ah,ai,aj,ak}my_week;
    enum day{monring, moon, aftermoon}my_day;
}weekday_st;

int main(int argc, char *argv[])
{
    printf("sizeof(weekday_st)=%d\n", sizeof(weekday_st));
    printf("sizeof(weekday)=%d\n", sizeof(weekday_st::week));
    printf("sizeof(day)=%d\n", sizeof(weekday_st::day));
    return 0;
}

这个时候结构体里面就不简单只是两个类型了,而是定义了一个week类型的变量my_week和一个day类型的变量my_day,这个时候的结果就是以下内容了

sizeof(weekday_st)=8
sizeof(weekday)=4
sizeof(day)=4

是不是还有一个疑问,接着看吧

printf("sizeof(weekday)=%d\n", sizeof(weekday_st::week));

printf("sizeof(day)=%d\n", sizeof(weekday_st::day));

enum实参被提升的时候,提升到下一个能够表示其所有枚举常量的类型.: int,unsigned int,long ,unsigned long,所以在你的机子上,sizeof(enum)都等于4也是正常的,所以枚举量是当作整型常量来处理的,所以上面这两个sizeof都是返回4

待续。。。。

原文地址:https://www.cnblogs.com/javawebsoa/p/3106628.html