• C与C++中的枚举


    1. C语言中 enum

    void test()
    
    {
    
    enum Week { Mon, Tue, Wed, Thi, Fri, Sat, Sun };
    
    enum Other { One, Two, Three };
    
    enum Week week = Mon;
    
    // 1. 允许非枚举值赋值给枚举类型, 允许其他枚举类型的值赋值给当前枚举类型
    
    week = 100; //ok
    
    week = One; //ok
    
    // 2. 枚举值具有外层作用域,容易造成名字冲突
    
    int One = 100; //error
    
    // 3. 不同类型的枚举值可以直接比较
    
    if (week == One)
    
    {
    
    printf("equal
    ");
    
    }
    
    }

    2. C++中 enum

    void test()
    
    {
    
    enum Week { Mon, Tue, Wed, Thi, Fri, Sat, Sun };
    
    enum Other { One, Two, Three };
    
    enum Week week = Mon;
    
    // 1. C++ 只能允许赋值枚举值
    
    // week = 100; //error
    
    // week = One; //error
    
    // 2. 枚举元素会暴露在外部作用域,不同的两个枚举类型,若含有相同枚举元素,则会冲突
    
    enum OtherWeek { Mon };
    
    // 3. C++ 只允许同枚举类型值之间比较
    
    // enum E1 { A, B }; //error
    
    // enum E2 { C, D }; //error
    
    // cout << (E1::B == E2::D ? "相等" : "不相等") << endl; //error
    
    }

    3. C++中的 enum class

    void test()
    
    {
    
    enum class E1 { A = 1, B = 2 };
    
    enum class E2 { A = 1, C = 2 };
    
    // 1. 强枚举类型不会将枚举元素暴露在外部作用域
    
    cout << (int)(E1::A) << endl;
    
    int A = 100;
    
    // 2. 不相关的两个枚举类型不能直接比较,编译报错
    
    cout << (E1::B == E2::C ? "相等" : "不相等") << endl; //error
    
    cout << (E1::B == 2 ? "相等" : "不相等") << endl; //error
    
    }

    总结

    1. C 枚举类型支持不同类型枚举值之间赋值、以及数字赋值、比较,并且具有外层作用域。

    2. C++ 中枚举不允许不同类型的值给枚举类型变量赋值,但仍然支持不同类型之间枚举进行比较,枚举符号常量具有挖外作用域。

    3. C++ 强枚举类型不允许不同类型之间的赋值、比较,枚举常量值并不具有外层作用域。

    在C++中使用时的重要提示

    • 枚举变量可以直接输出,但不能直接输入。如:cout >> color3;   //非法
    • 不能直接将常量赋给枚举变量。如:  color1=1; //非法
    • 不同类型的枚举变量之间不能相互赋值。如: color1=color3;  //非法
    • 枚举变量的输入输出一般都采用switch语句将其转换为字符或字符串;枚举类型数据的其他处理也往往应用switch语句,以保证程序的合法性和可读性。

    C++枚举应用实例:

    口袋中有红、黄、蓝、白、黑五种颜色的球若干个,每次从口袋中取三个不同颜色的球,统计并输出所有的取法。

    分析:由于球只能是五种颜色之一,故可用枚举类型表示球的颜色。设取出的球为i、j、k,根据题意,i、j、k分别可以有五种取值,且i≠j≠k。可以用穷举法,逐个检验每一种可能的组合,从中找出符合要求的组合并输出。

    #include<iostream>
    #include<iomanip>
    using namespace std;
    int main(){
        enum color_set {red,yellow,blue,white,black}; //声明枚举类型color
        color_set color; 
        int i,j,k,counter=0,loop; //counter是累计不同颜色的组合数
        for(i=red;i<=black;i++) {
            for(j=red;j<=black;j++) {
                if(i!=j){                        //前两个球颜色不同
                    for(k=red;k<=black;k++)
                    if(k!=i&&k!=j){        //第三个球不同于前两个,满足要求
                        counter++;
                        if((counter)%22==0){ //每屏显示22行
                            cout<<"请按回车键继续";
                            cin.get();
                        }
                        cout<<setw(15)<<counter;
                        /*下面输出每种取法,一行为一种取法的三个颜色*/
                        for(loop=1;loop<=3;loop++){
                            switch(loop){
                                case 1: color=(color_set) i; break;    //第一个是i
                                case 2: color=(color_set) j; break;    //第二个是j
                                case 3: color=(color_set) k; break;    //第三个是k
                            }
                            switch(color){
                                case red:   cout<<setw(15)<<"red";   break;
                                case yellow:cout<<setw(15)<<"yellow";break;
                                case blue:  cout<<setw(15)<<"blue";  break;
                                case white:    cout<<setw(15)<<"white"; break;
                                case black: cout<<setw(15)<<"black"; break;
                            }
                        }
                        cout<<endl;            //输出一种取法后换行
                    }
                }
            }
        }
        cout<<"共有:"<<counter<<"种取法"<<endl;
        return 0;
    }
  • 相关阅读:
    python的内存管理
    redis 为啥要主从复制·
    django框架的ORM模型优缺点
    Pytorch学习:实现ResNet34网络
    Pytorch学习:线性回归
    Pytorch学习:CIFAR-10分类
    论文阅读笔记(六十七)【arXiv2021】:Contextual Non-Local Alignment over Full-Scale Representation for Text-Based Person Search
    论文阅读笔记(六十六)【ICCV2019】:Adversarial Representation Learning for Text-to-Image Matching
    论文阅读笔记(六十五)【ECCV2018】:Deep Cross-Modal Projection Learning for Image-Text Matching
    论文阅读笔记(六十四)【arXiv2021】:TransReID: Transformer-based Object Re-Identification
  • 原文地址:https://www.cnblogs.com/wddx5/p/13297228.html
Copyright © 2020-2023  润新知