typedef NS_ENUM 等枚舉介紹

枚舉其實很重要,特別是在應用開發初期,服務器端數據格式須要更改得狀況下,枚舉和宏都能是程序簡潔,而且改動小。服務器

首先要知道的是,枚舉值 它是一個整形(int) 而且,它不參加內存的佔用和釋放 枚舉定義變量便可直接使用,不用初始化. 枚舉的定義以下:
spa

typedef enum {內存

//如下是枚舉成員 TestA = 0,開發

    TestB,  變量

    TestC,  原理

    TestD 服務器端

}Test;//枚舉名稱二進制

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

typedef NS_ENUM(NSInteger, Test1) {數據

//如下是枚舉成員

    Test1A = 0,

    Test1B = 1,

    Test1C = 2,

    Test1D = 3

};

枚舉的定義還支持位運算的方式定義,以下: 等於號後面必須等於1

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個數字,不管你如何組合在一塊兒,也不會產生兩個一樣的數字.

多枚舉值 賦值方式以下:

Test tes = (TestA|TestB);

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

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

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

 tes^= TestE;  

相關文章
相關標籤/搜索