博客
关于我
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 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>