enum的使用 ios
2017-12-07 16:06:41 souprock 阅读数 94

之前有个功能是从一个页面不同状态的时候跳入另一个页面,我是在后一个页面定义一个属性,根据不同状态给那个属性赋不同值来判断,之前是定义NSNumber类型的属性,然后随意自己制定1,2,3来区分状态,后来觉得很不直观,所以决定用枚举来做这个功能,使用枚举之后确实直观方便了不少。

复制代码
//最初的enum的定义
typedef enum { printOrder = 1, hubSolveOrder = 2, } orderForm; //Foundation框架已经为我们提供了更加“统一、便捷”的枚举定义方法 //NS_ENUM,定义状态等普通枚举 typedef NS_ENUM(NSUInteger,orderForm) { printOrder = 1, hubSolveOrder = 2, } ;

复制代码
//使用的时候 在.h文件中定义一个枚举属性
@property (nonatomic, assign) orderForm orderform;


//在.m文件中可以根据属性赋值的不同,进行不同的操作

 像这种类似问题应该还有很多,自己要慢慢探索,进一步提高代码的可读性。

2013-03-15 09:56:00 iteye_7514 阅读数 13
首先要知道的是,枚举值 它是一个整形(int) 并且,它不参加内存的占用和释放枚举定义变量即可直接使用,不用初始化. 枚举的定义如下:

typedef enum {

//以下是枚举成员 TestA = 0,

<wbr><wbr> TestB,<wbr></wbr></wbr></wbr>

<wbr><wbr> TestC,<wbr></wbr></wbr></wbr>

<wbr><wbr>TestD<wbr></wbr></wbr></wbr>

}Test;//枚举名称

亦可以如下定义(推荐:结构比较清晰):

typedef NS_ENUM(NSInteger, Test1) {

//以下是枚举成员

<wbr><wbr> Test1A = 0,</wbr></wbr>

<wbr><wbr> Test1B = 1,</wbr></wbr>

<wbr><wbr> Test1C = 2,</wbr></wbr>

<wbr><wbr> Test1D = 3</wbr></wbr>

};


枚举的定义还支持位运算的方式定义,如下: 等于号后面必须等于1

typedef NS_ENUM(NSInteger, Test) {

<wbr><wbr> TestA = 1, //1 1 1</wbr></wbr>

<wbr><wbr> TestB = 1 &lt;&lt; 1, //22 10 转换成 10进制 2</wbr></wbr>

<wbr><wbr> TestC = 1 &lt;&lt; 2, //43 100 转换成 10进制 4</wbr></wbr>

<wbr><wbr> TestD = 1 &lt;&lt; 3, //84 1000 转换成 10进制 8</wbr></wbr>

<wbr><wbr> TestE = 1 &lt;&lt; 4 //165 10000 转换成 10进制 16</wbr></wbr>

};


什么时候要用到这种方式呢? 那就是一个枚举变量可能要代表多个枚举值的时候.其实给一个枚举变量赋予多个枚举值的时候,原理只是把各个枚举值加起来罢了.当加起来以后,就获取了一个新的值,那么为了保证这个值的唯一性,这个时候就体现了位运算的重要作用. 位运算可以确保枚举值组合的唯一性.因为位运算的计算方式是将二进制转换成十进制,也就是说,枚举值里面存取的是 计算后的十进制值. 打个比方:通过上面的位运算方式设定好枚举以后,打印出来的枚举值分别是: 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(@"没有"); } <wbr></wbr>

NSLog(@"%d",(tes & TestC));

if ((tes & TestC)) { NSLog(@"有"); }

else { NSLog(@"没有"); }


如果 没有包含,将返回0, 0表示false NO 则进入else也可以随时为枚举变量累加某个值,但是要自己控制不要添加已经加入过的枚举值, 枚举变量的值不会有变动,但这样将会误导阅读代码的人

有累加,自然有累减了,如果累减不存在的枚举值, 那么本次累减的枚举值,会自动累加上去.

<wbr>tes^= TestE; <wbr></wbr></wbr>


2015-12-30 10:38:14 huzhaohao 阅读数 416

枚举其实很重要,特别是在应用开发初期,服务器端数据格式需要更改得情况下,枚举和宏都能是程序简洁,并且改动小。

网上有个人写的言简意赅,适合初学

转自:http://blog.csdn.net/ysy441088327/article/details/8012677

题记: 蛋疼的枚举, 千万别小视了! 进入正题: 首先要知道的是,枚举值 它是一个整形(int) 并且,它不参加内存的占用和释放枚举定义变量即可直接使用,不用初始化. 枚举的定义如下:

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, //22 10 转换成 10进制 2

    TestC = 1 << 2, //43 100 转换成 10进制 4

    TestD = 1 << 3, //84 1000 转换成 10进制 8

    TestE = 1 << 4 //165 10000 转换成 10进制 16

};


2013-03-15 09:56:27 MyGameZone 阅读数 1884
首先要知道的是,枚举值 它是一个整形(int) 并且,它不参加内存的占用和释放枚举定义变量即可直接使用,不用初始化. 枚举的定义如下:

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, //22 10 转换成 10进制 2

    TestC = 1 << 2, //43 100 转换成 10进制 4

    TestD = 1 << 3, //84 1000 转换成 10进制 8

    TestE = 1 << 4 //165 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;  


2017-02-14 15:13:00 weixin_34152820 阅读数 14

枚举值一般是4个字节的int值,在64位系统上是8个字节。

一般定义枚举的时候如下:


2658586-e9efdbcb44846f32.png

枚举一般默认从0开始。

这里输出Father,Mother,Borther,Sister分别是 0、 1、 2、3

位移操作枚举定义如下:


2658586-cee5beccaac70a8b.png

这里位移枚举变量的算法是把后面的每个枚举值相加,将其对应的二进制转化为十进制就是该枚举变量的唯一值。

Father  =  0               //   0

Mother =  1 << 0      //    1    1

Brother = 1 <<  1      //    1 + 1 = 2(2进制位数)  =  10   转化为十进制   2

SisterA =  1 <<  2    //    1 + 2 = 3(2进制位数)  =  100  转化为十进制  4

SisterB =  1 <<  3    //    1 + 3 = 4(2进制位数)  =  1000  转化为十进制  8

SisterC =  1 <<  4    //    1 + 4 = 5(2进制位数)  =  10000  转化为十进制  16

SisterD =  1 <<  5    //    1 + 5 = 6(2进制位数)  =  100000  转化为十进制  32

这里输出Father,Mother,Borther,SisterA,SisterB,SisterC,SisterD分别是 0、 1、 2、4、8、16、32

在iOS6和Mac OS 10.8以后Apple引入了两个宏来重新定义这两个枚举类型。

关于enum 建议使用 NS_ENUM 和 NS_OPTIONS 宏来定义枚举类型,参见官方的 How to Adopt

以上两种枚举定义建议更改如下:


2658586-4e71829bd2c9e501.png

NS_OPTIONS一般用来定义位移相关操作的枚举值


2658586-3dd7166b9dd91d32.png

下面是苹果官方文档给出的enum更换举例:

正常枚举值举例:

2658586-436e9f88ea45e85f.png

位移相关操作的枚举值举例:

2658586-17a15416931bf4e5.png

iOS枚举(enum)

阅读数 119

ios enum to string

阅读数 929

iOS - 枚举(Enum)

阅读数 20

常见的ios的enum

阅读数 3123

ios的枚举ENUM

阅读数 591

没有更多推荐了,返回首页