教育行業A股IPO第一股(股票代碼 003032)

全國咨詢/投訴熱線:400-618-4000

C與C++中的enum有什么不同?[C語言培訓]

更新時間:2020年01月16日14時17分 來源:傳智播客 瀏覽次數:

傳智播客


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\n");

         }

}

   

其中第二種情況錯誤提示如下:

1579140127125_C++的枚舉01.jpg


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

}

我們看到第二種情況仍然報錯如下:

1579140137348_C++的枚舉02.jpg


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

}

   

報錯信息如下:

由此我們可以看到,強枚舉類型禁止不同枚舉類型之間進行比較。 

1579140146857_C++的枚舉03.jpg


4. 總結

1. C 枚舉類型支持不同類型枚舉值之間賦值、以及數字賦值、比較,并且具有外層作用域。

2. C++ 中枚舉不允許不同類型的值給枚舉類型變量賦值,但仍然支持不同類型之間枚舉進行比較,枚舉符號常量具有挖外作用域。

3. C++ 強枚舉類型不允許不同類型之間的賦值、比較,枚舉常量值并不具有外層作用域。推薦了解傳智播客C++培訓課程。

猜你喜歡:

C/C++面向對象和java面向對象的區別

0 分享到:
红豆直播app黄台_红豆直播app下载免费_红豆直播app下载