博客
关于我
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中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>