• 18-枚举


    一、枚举的概念

    枚举是C语言中的一种基本数据类型,并不是构造类型,它可以用于声明一组常数。当一个变量有几个固定的可能取值时,可以将这个变量定义为枚举类型比如,你可以用一个枚举类型的变量来表示季节,因为季节只有4种可能的取值:春天、夏天、秋天、冬天。

    二、枚举类型的定义

    一般形式为:enum 枚举名 {枚举元素1,枚举元素2,……};

    enum Season {spring, summer, autumn, winter}; 

    三、枚举变量的定义

    前面只是定义了枚举类型,接下来就可以利用定义好的枚举类型定义变量。

    跟结构体一样,有3种方式定义枚举变量

    1.先定义枚举类型,再定义枚举变量

    enum Season {spring, summer, autumn, winter}; 
    
    enum Season s; 

    2.定义枚举类型的同时定义枚举变量

    enum Season {spring, summer, autumn, winter} s; 

    3.省略枚举名称,直接定义枚举变量

    enum {spring, summer, autumn, winter} s; 

    上面三种方式定义的都是枚举变量s

    四、枚举使用的注意

    1> C语言编译器会将枚举元素(spring、summer等)作为整型常量处理,称为枚举常量。

    2> 枚举元素的值取决于定义时各枚举元素排列的先后顺序。默认情况下,第一个枚举元素的值为0,第二个为1,依次顺序加1。

    enum Season {spring, summer, autumn, winter}; 

    也就是说spring的值为0,summer的值为1,autumn的值为2,winter的值为3.

    3> 也可以在定义枚举类型时改变枚举元素的值

    enum season {spring, summer=3, autumn, winter}; 

    没有指定值的枚举元素,其值为前一元素加1。也就说spring的值为0,summer的值为3,autumn的值为4,winter的值为5

    #include <stdio.h>
    #include <stdlib.h>
    
    /* run this program using the console pauser or add your own getch, system("pause") or input loop */
    
    
    int main(int argc, const char * argv[]) {
        // 定义一个结构体类型
    enum Season {spring, summer, autumn=5, winter} s;
    
    // 遍历枚举元素
    for (s = spring; s <= winter; s++) {
        printf("枚举元素:%d 
    ", s);
    }
    }
    View Code

    五、枚举变量的基本操作

    1.赋值

    可以给枚举变量赋枚举常量或者整型值

    enum Season {spring, summer, autumn, winter} s;
    
    s = spring; // 等价于 s = 0;
    
    s = 3; // 等价于 s = winter;

    2.遍历枚举元素

    复制代码
    enum Season {spring, summer, autumn, winter} s;
    
    // 遍历枚举元素
    for (s = spring; s <= winter; s++) {
        printf("枚举元素:%d 
    ", s);
    }
    复制代码

    输出结果:

  • 相关阅读:
    DOM基础
    9个实用的Javascript代码高亮脚本
    去掉超链接虚线框去掉chrome浏览器中input或textarea在得到焦点时出现黄色边框和取消可以拖动大小
    我的Gvim配置文件
    收集的一些有关UED的团队和个人博客
    JS函数:返回下一个元素节点而不是下一个节点
    分享一款图片导航效果 Animated Slideshow Navigation
    原生javascript写的Tab菜单(函数版)
    单个select语句实现MySQL查询统计次数
    mysql 语句case when
  • 原文地址:https://www.cnblogs.com/0zcl/p/6084020.html
Copyright © 2020-2023  润新知