博客
关于我
C/C++枚举类型
阅读量:516 次
发布时间:2019-03-07

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

C/C++枚举类型

上节我们介绍了结构体。

本节我们介绍枚举类型enum。

概念

  • 枚举类型是C/C++语言中的一种基本数据类型,它可以用于声明一组常数。当一个变量有几个固定的取值时,可以将这个变量定义为枚举类型。可以提高代码的可读性。
    比如可以用一个枚举变量表示月份,因为只有12个月。
    也可以表示季节。

类型的定义

  • 一般形式为: enum 枚举名 { 枚举元素1, 枚举元素2, …};
    上面的月份可以表示为 enum Month{ January, February, March, ......};
  • 在VS2019新版本中,建议把enum定义为类类型,也就是使用enum class来定义枚举类,防止出问题。

变量的定义

  • 进行季节的枚举定义:

    #include 
    using namespace std;//定义一个枚举类型enum Seasons { Spring, Summer, Autumn, Winter};int main() { //定义两个枚举变量 enum Seasons s1, s2; s1 = Spring, s2 = Summer; //打印s1与s2的值,Spring与Summer的值 cout << s1 << " " << s2 << endl; return 0;}

    输出结果:

    0 1
  • 本质,枚举类型中的成员的值是固定的,可以在类中修改,只是用记号来代表常数的排列

  • 注意:不能给枚举变量赋值整数! 如:s1 = 4;建议不要使用强制类型转换(enum Seasons)。可能超出表达的范围

  • 和结构体相同,枚举的定义也有好几种方式:

    //定义一个枚举类型再定义枚举变量常用enum Seasons {     	Spring,    Summer,    Autumn,    Winter};enum Seasons s;//定义枚举类型的同时定义变量enum Seasons {     	Spring,    Summer,    Autumn,    Winter}s;//省略类型名,直接定义变量enum {     	Spring,    Summer,    Autumn,    Winter}s;

    上面三种都相当于定义枚举变量s,其中第二种与第三种定义的相当于是全局变量

  • 注意: 第二种方式定义类型的时候就定义了一个变量,后面可以新添加枚举变量。

    第三种方式,只能在刚开始时定义一个或者多个枚举变量。

使用注意

  • C语言编译器会把枚举元素(Spring, Summer…)作为整型常量处理,称为枚举常量。

  • 枚举元素的值取决于定义时的先后顺序,默认情况下,第一个元素为0,第二个元素为1,后面一个元素为前面一个元素+1。

    实例:

    #include 
    using namespace std;//定义一个枚举类型enum Seasons { Spring, Summer = 4, Autumn, Winter};int main() { //定义两个枚举变量 enum Seasons s1, s2, s3; s1 = Spring, s2 = Summer, s3 = Autumn; //打印s1与s2的值,Spring与Summer的值 cout << s1 << " " << s2 << " " << s3 << endl; return 0;}

    输出结果:

    0 4 5
  • 枚举变量的大小,和整型变量一样,占四个字节。

本节我们介绍了枚举类型,下节我们介绍类型定义(typedef)。

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

你可能感兴趣的文章
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL一站到底!华为首发MySQL进阶宝典,基础+优化+源码+架构+实战五飞
查看>>
MySQL万字总结!超详细!
查看>>
Mysql下载以及安装(新手入门,超详细)
查看>>
MySQL不会性能调优?看看这份清华架构师编写的MySQL性能优化手册吧
查看>>
MySQL不同字符集及排序规则详解:业务场景下的最佳选
查看>>
Mysql不同官方版本对比
查看>>
MySQL与Informix数据库中的同义表创建:深入解析与比较
查看>>
mysql与mem_细说 MySQL 之 MEM_ROOT
查看>>
MySQL与Oracle的数据迁移注意事项,另附转换工具链接
查看>>
mysql丢失更新问题
查看>>
MySQL两千万数据优化&迁移
查看>>
MySql中 delimiter 详解
查看>>
MYSQL中 find_in_set() 函数用法详解
查看>>
MySQL中auto_increment有什么作用?(IT枫斗者)
查看>>