ios 枚舉 位移操做

引言:ui

枚舉 它是一個整形(int)  而且,它不參與內存的佔用和釋放,枚舉定義變量便可直接使用,不用初始化.spa

在代碼中使用枚舉的目的只有一個,那就是增長代碼的可讀性..net

 

使用:blog

枚舉的定義以下:ip

[csharp]  view plain copy
  1. typedef enum  
  2. {  
  3.     //如下是枚舉成員  
  4.     TestA = 0,  
  5.     TestB,  
  6.     TestC,  
  7.     TestD  
  8. }Test;//枚舉名稱  


亦能夠以下定義(推薦:結構比較清晰):內存

[csharp]  view plain copy
  1. typedef NS_ENUM(NSInteger, Test1)  
  2. {  
  3.     //如下是枚舉成員  
  4.     Test1A = 0,  
  5.     Test1B = 1,  
  6.     Test1C = 2,  
  7.     Test1D = 3  
  8. };  


枚舉的定義還支持位運算的方式定義,以下:get

等於號後面必須等於1string

[csharp]  view plain copy
  1. typedef NS_ENUM(NSInteger, Test)  
  2. {  
  3.     TestA       = 1,      //1   1   1  
  4.     TestB       = 1 << 1, //2   2   10      轉換成 10進制  2  
  5.     TestC       = 1 << 2, //4   3   100     轉換成 10進制  4  
  6.     TestD       = 1 << 3, //8   4   1000    轉換成 10進制  8  
  7.     TestE       = 1 << 4  //16  5   10000   轉換成 10進制  16  
  8. };  

何時要用到這種方式呢?it

那就是一個枚舉變量可能要表明多個枚舉值的時候. 其實給一個枚舉變量賦予多個枚舉值的時候,原理只是把各個枚舉值加起來罷了.class

當加起來之後,就獲取了一個新的值,那麼爲了保證這個值的惟一性,這個時候就體現了位運算的重要做用.

位運算能夠確保枚舉值組合的惟一性.

由於位運算的計算方式是將二進制轉換成十進制,也就是說,枚舉值裏面存取的是 計算後的十進制值.

打個比方:

經過上面的位運算方式設定好枚舉之後,打印出來的枚舉值分別是: 1 2 4 8 16

這5個數字,不管你如何組合在一塊兒,也不會產生兩個一樣的數字.

手工的去建立位運算枚舉,還有稍微有點花時間的,好在Apple已經爲咱們準備的uint.因此,用下面這種方式來初始化一個位運算枚舉吧:

[csharp]  view plain copy
  1. typedef NS_ENUM(uint, Test)  
  2. {  
  3.     TestA,  
  4.     TestB,  
  5.     TestC,  
  6.     TestD,  
  7.     TestE    
  8. };  



 

 

多枚舉值 賦值方式以下:

[csharp]  view plain copy
  1. Test tes = (TestA|TestB);  


判斷枚舉變量是否包含某個固定的枚舉值,使用前須要確保枚舉值以及各個組合的惟一性:

[csharp]  view plain copy
  1. NSLog(@"%d %d %d %d %d",TestA,TestB,TestC,TestD,TestE);  
  2. Test tes = (TestA|TestB);  
  3. NSLog(@"%d",tes);  
  4. NSLog(@"%d",(tes & TestA));  
  5.   
  6. if ((tes & TestA)) {  
  7.     NSLog(@"有");  
  8. }else  
  9. {  
  10.     NSLog(@"沒有");  
  11. }  
  12. NSLog(@"%d",(tes & TestB));  
  13. if ((tes & TestA)) {  
  14.     NSLog(@"有");  
  15. }else  
  16. {  
  17.     NSLog(@"沒有");  
  18. }  
  19.   
  20. NSLog(@"%d",(tes & TestC));  
  21. if ((tes & TestC)) {  
  22.     NSLog(@"有");  
  23. }else  
  24. {  
  25.     NSLog(@"沒有");  
  26. }  

若是 沒有包含,將返回0, 0表示false NO 則進入else

也能夠隨時爲枚舉變量累加某個值,可是要本身控制不要添加已經加入過的枚舉值, 枚舉變量的值不會有變更,但這樣將會誤導閱讀代碼的人

[csharp]  view plain copy
  1. tes |=TestC;  

 

有累加,天然有累減了,若是累減不存在的枚舉值, 那麼本次累減的枚舉值,會自動累加上去.

[csharp]  view plain copy
    1. tes^= TestE;  
相關文章
相關標籤/搜索