標籤:
引言:
http://blog.csdn.net/ysy441088327/article/details/8012677
枚舉值 它是一個整形(int) 並且,它不參與記憶體的佔用和釋放,枚舉定義變數即可直接使用,不用初始化.
在代碼中使用枚舉的目的只有一個,那就是增加代碼的可讀性.
使用:
枚舉的定義如下:
[csharp] view plaincopy
- typedef enum
- {
- //以下是枚舉成員
- TestA = 0,
- TestB,
- TestC,
- TestD
- }Test;//枚舉名稱
亦可以如下定義(推薦:結構比較清晰):
[csharp] view plaincopy
- typedef NS_ENUM(NSInteger, Test1)
- {
- //以下是枚舉成員
- Test1A = 0,
- Test1B = 1,
- Test1C = 2,
- Test1D = 3
- };
枚舉的定義還支援位元運算的方式定義,如下:
等號後面必須等於1
[csharp] view plaincopy
- typedef NS_ENUM(NSInteger, Test)
- {
- TestA = 1, //1 1 1
- TestB = 1 << 1, //2 2 10 轉換成 10進位 2
- TestC = 1 << 2, //4 3 100 轉換成 10進位 4
- TestD = 1 << 3, //8 4 1000 轉換成 10進位 8
- TestE = 1 << 4 //16 5 10000 轉換成 10進位 16
- };
什麼時候要用到這種方式呢?
那就是一個枚舉變數可能要代表多個枚舉值的時候. 其實給一個枚舉變數賦予多個枚舉值的時候,原理只是把各個枚舉值加起來罷了.
當加起來以後,就擷取了一個新的值,那麼為了保證這個值的唯一性,這個時候就體現了位元運算的重要作用.
位元運算可以確保枚舉值組合的唯一性.
因為位元運算的計算方式是將二進位轉換成十進位,也就是說,枚舉值裡面存取的是 計算後的十進位值.
打個比方:
通過上面的位元運算方式設定好枚舉以後,列印出來的枚舉值分別是: 1 2 4 8 16
這5個數字,無論你如何組合在一起,也不會產生兩個同樣的數字.
手工的去建立位元運算枚舉,還有稍微有點花時間的,好在Apple已經為我們準備的uint.所以,用下面這種方式來初始化一個位元運算枚舉吧:
[csharp] view plaincopy
- typedef NS_ENUM(uint, Test)
- {
- TestA,
- TestB,
- TestC,
- TestD,
- TestE
- };
多枚舉值 賦值方式如下:
[csharp] view plaincopy
- Test tes = (TestA|TestB);
判斷枚舉變數是否包含某個固定的枚舉值,使用前需要確保枚舉值以及各個組合的唯一性:
[csharp] view plaincopy
- NSLog(@"%d %d %d %d %d",TestA,TestB,TestC,TestD,TestE);
- Test tes = (TestA|TestB);
- NSLog(@"%d",tes);
- NSLog(@"%d",(tes & TestA));
-
- if ((tes & TestA)) {
- NSLog(@"有");
- }else
- {
- NSLog(@"沒有");
- }
- NSLog(@"%d",(tes & TestB));
- if ((tes & TestA)) {
- NSLog(@"有");
- }else
- {
- NSLog(@"沒有");
- }
-
- NSLog(@"%d",(tes & TestC));
- if ((tes & TestC)) {
- NSLog(@"有");
- }else
- {
- NSLog(@"沒有");
- }
如果 沒有包含,將返回0, 0表示false NO 則進入else
也可以隨時為枚舉變數累加某個值,但是要自己控制不要添加已經加入過的枚舉值, 枚舉變數的值不會有變動,但這樣將會誤導閱讀代碼的人
[csharp] view plaincopy
- tes |=TestC;
有累加,自然有累減了,如果累減不存在的枚舉值, 那麼本次累減的枚舉值,會自動累加上去.
[csharp] view plaincopy
- tes^= TestE;
iOS 關於枚舉的使用