博客
关于我
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及navicat for mysql中文乱码
查看>>
MySqL双机热备份(二)--MysqL主-主复制实现
查看>>
MySQL各个版本区别及问题总结
查看>>
MySql各种查询
查看>>
mysql同主机下 复制一个数据库所有文件到另一个数据库
查看>>
mysql启动以后会自动关闭_驾照虽然是C1,一直是开自动挡的车,会不会以后就不会开手动了?...
查看>>
mysql启动和关闭外键约束的方法(FOREIGN_KEY_CHECKS)
查看>>
Mysql启动失败解决过程
查看>>
MySQL启动失败:Can't start server: Bind on TCP/IP port
查看>>
mysql启动报错
查看>>
mysql启动报错The server quit without updating PID file几种解决办法
查看>>
MySQL命令行登陆,远程登陆MySQL
查看>>
mysql命令:set sql_log_bin=on/off
查看>>
mySQL和Hive的区别
查看>>
MySQL和Java数据类型对应
查看>>
mysql和oorcale日期区间查询【含左右区间问题】
查看>>
MYSQL和ORACLE的一些操作区别
查看>>
mysql和redis之间互相备份
查看>>
MySQL和SQL入门
查看>>
mysql在centos下用命令批量导入报错_Variable ‘character_set_client‘ can‘t be set to the value of ‘---linux工作笔记042
查看>>