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;  
相关文章
相关标签/搜索