博客
关于我
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/

你可能感兴趣的文章
MySQL8修改密码的方法
查看>>
Mysql8在Centos上安装后忘记root密码如何重新设置
查看>>
Mysql8在Windows上离线安装时忘记root密码
查看>>
MySQL8找不到my.ini配置文件以及报sql_mode=only_full_group_by解决方案
查看>>
mysql8的安装与卸载
查看>>
MySQL8,体验不一样的安装方式!
查看>>
MySQL: Host '127.0.0.1' is not allowed to connect to this MySQL server
查看>>
Mysql: 对换(替换)两条记录的同一个字段值
查看>>
mysql:Can‘t connect to local MySQL server through socket ‘/var/run/mysqld/mysqld.sock‘解决方法
查看>>
MYSQL:基础——3N范式的表结构设计
查看>>
MYSQL:基础——触发器
查看>>
Mysql:连接报错“closing inbound before receiving peer‘s close_notify”
查看>>
mysqlbinlog报错unknown variable ‘default-character-set=utf8mb4‘
查看>>
mysqldump 参数--lock-tables浅析
查看>>
mysqldump 导出中文乱码
查看>>
mysqldump 导出数据库中每张表的前n条
查看>>
mysqldump: Got error: 1044: Access denied for user ‘xx’@’xx’ to database ‘xx’ when using LOCK TABLES
查看>>
Mysqldump参数大全(参数来源于mysql5.5.19源码)
查看>>
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>