博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
enum枚举介绍
阅读量:2240 次
发布时间:2019-05-09

本文共 1787 字,大约阅读时间需要 5 分钟。

C/C++程序语言中的一种数据类型  

枚举类型在实际问题中,有些变量的取值被限定在一个有限的范围内。例如,一个星期内只有七天,一年只有十二个月,一个班每周有六门课程等等。如果把这些量说明为整型,字符型或其它类型显然是不妥当的。为此,C语言提供了一种称为“枚举”的类型。在“枚举”类型的定义中列举出所有可能的取值,被说明为该“枚举”类型的变量取值不能超过定义的范围。应该说明的是,枚举类型是一种基本数据类型,而不是一种构造类型,因为它不能再分解为任何基本类型。枚举类型的定义和枚举变量的说明枚举的主要目的,我觉得就是使代码的可读性更好。如果没有枚举,其所要实现的功能也可以通过其它方式实现。枚举值本身就是一个符号,但是它又有一个int值的属性。可以看看书,就不多说了。枚举值就是一些命名,通过其命名就能知道其真正的意义。

1. 枚举的定义枚举类型定义的一般形式为

enum 枚举名{ 枚举值表 };

enum 枚举名{枚举值1,枚举值2,枚举值3,.....}

  在枚举值表中应罗列出所有可用值。这些值也称为枚举元素。  

例如:  

该枚举名为weekday,枚举值共有7个,即一周中的七天。

凡被说明为weekday类型变量的取值只能是七天中的某一天。  

2. 枚举变量的说明  

如同结构和联合一样,枚举变量也可用不同的方式说明,即先定义后说明,同时定义说明或直接说明。  

设有变量a,b,c被说明为上述的weekday,可采用下述任一种方式:  

enum weekday{ sun,mon,tue,wed,thu,fri,sat };  

enum weekday a,b,c;  

或者为:  enum weekday{ sun,mon,tue,wed,thu,fri,sat }a,b,c;  

或者为:  enum { sun,mon,tue,wed,thu,fri,sat }a,b,c;枚举类型变量的赋值和使用  

枚举类型在使用中有以下规定:  

1. 枚举值是常量,不是变量。不能在程序中用赋值语句再对它赋值。  

例如对枚举weekday的元素再作以下赋值:  sun=5;  mon=2;  sun=mon;  都是错误的。  

2. 枚举元素本身由系统定义了一个表示序号的数值,从0开始顺序定义为0,1,2…。如在weekday中,sun值为0,mon值为1,…,sat值为6。  

【例11.10】  

main(){  

    enum weekday  

   {

    sun,mon,tue,wed,thu,fri,sat

   } a,b,c;  

   a=sun;  

   b=mon;  

  c=tue;  

  printf("%d,%d,%d",a,b,c);

  }  

/*说明:  只能把枚举值赋予枚举变量,不能把元素的数值直接赋予枚举变量。如:  

a=sun;  

b=mon;  是正确的。

而:  a=0;  b=1;  是错误的。

如一定要把数值赋予枚举变量,则必须用强制类型转换。  

如:  a=(enum weekday)2;  

其意义是将顺序号为2的枚举元素赋予枚举变量a,相当于:  

a=tue;  

还应该说明的是枚举元素不是字符常量也不是字符串常量,使用时不要加单、双引号。 */

 【例11.11】  

#include<stdio.h>   

int main(){ 

enum body  

{

a,b,c,d } month[31],j;  

int i1;  j=a;  

for(i1=1;i1<=30;i1++){

  month[i1]=j;  j++;  if (j>d) j=a;  

}  

for(i1=1;i1<=30;i1++){  

switch(month)  {  

case a:printf(" - %c\t",i1,'a'); break;  

case b:printf(" - %c\t",i1,'b'); break;  

case c:printf(" - %c\t",i1,'c'); break;  

case d:printf(" - %c\t",i1,'d'); break;  

default:break;  }  

}  

printf("\n");  

}

转载地址:http://foqbb.baihongyu.com/

你可能感兴趣的文章
Java集合详解3:一文读懂Iterator,fail-fast机制与比较器
查看>>
Java集合详解4:一文读懂HashMap和HashTable的区别以及常见面试题
查看>>
Java集合详解5:深入理解LinkedHashMap和LRU缓存
查看>>
Java集合详解6:这次,从头到尾带你解读Java中的红黑树
查看>>
Java集合详解8:Java集合类细节精讲,细节决定成败
查看>>
Java并发指南1:并发基础与Java多线程
查看>>
Java并发指南2:深入理解Java内存模型JMM
查看>>
Java并发指南5:JMM中的final关键字解析
查看>>
Java并发指南6:Java内存模型JMM总结
查看>>
Java并发指南7:JUC的核心类AQS详解
查看>>
Java并发指南8:AQS中的公平锁与非公平锁,Condtion
查看>>
Java网络编程和NIO详解6:Linux epoll实现原理详解
查看>>
Java网络编程和NIO详解7:浅谈 Linux 中NIO Selector 的实现原理
查看>>
Java网络编程与NIO详解8:浅析mmap和Direct Buffer
查看>>
Java网络编程与NIO详解10:深度解读Tomcat中的NIO模型
查看>>
Java网络编程与NIO详解11:Tomcat中的Connector源码分析(NIO)
查看>>
深入理解JVM虚拟机1:JVM内存的结构与消失的永久代
查看>>
深入理解JVM虚拟机3:垃圾回收器详解
查看>>
深入理解JVM虚拟机4:Java class介绍与解析实践
查看>>
深入理解JVM虚拟机5:虚拟机字节码执行引擎
查看>>