枚举其实很重要,特别是在应用开发初期,服务器端数据格式需要更改得情况下,枚举和宏都能是程序简洁,并且改动小。 网上有个人写的言简意赅,适合初学 转自:http://blog.csdn.net/ysy441088327/article/details/8012677 题记: 蛋疼的枚举, 千万别小视了! 进入正题: 首先要知道的是,枚举值 它是一个整形(int) 并且,它不参加内存的占用和释放 枚举定义变量即可直接使用,不用初始化. 枚举的定义如下: typedef enum { //以下是枚举成员 TestA = 0, }Test;//枚举名称 亦可以如下定义(推荐:结构比较清晰): typedef NS_ENUM(NSInteger, Test1) { //以下是枚举成员 }; 枚举的定义还支持位运算的方式定义,如下: 等于号后面必须等于1 typedef NS_ENUM(NSInteger, Test) { }; 什么时候要用到这种方式呢? 那就是一个枚举变量可能要代表多个枚举值的时候. 其实给一个枚举变量赋予多个枚举值的时候,原理只是把各个枚举值加起来罢了. 当加起来以后,就获取了一个新的值,那么为了保证这个值的唯一性,这个时候就体现了位运算的重要作用. 位运算可以确保枚举值组合的唯一性. 因为位运算的计算方式是将二进制转换成十进制,也就是说,枚举值里面存取的是 计算后的十进制值. 打个比方: 通过上面的位运算方式设定好枚举以后,打印出来的枚举值分别是: 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 也可以随时为枚举变量累加某个值,但是要自己控制不要添加已经加入过的枚举值, 枚举变量的值不会有变动,但这样将会误导阅读代码的人 有累加,自然有累减了,如果累减不存在的枚举值, 那么本次累减的枚举值,会自动累加上去. ========= 引言: 枚举值 它是一个整形(int) 并且,它不参与内存的占用和释放,枚举定义变量即可直接使用,不用初始化. 在代码中使用枚举的目的只有一个,那就是增加代码的可读性. 使用: 枚举的定义如下:
亦可以如下定义(推荐:结构比较清晰):
枚举的定义还支持位运算的方式定义,如下: 等于号后面必须等于1
那就是一个枚举变量可能要代表多个枚举值的时候. 其实给一个枚举变量赋予多个枚举值的时候,原理只是把各个枚举值加起来罢了. 当加起来以后,就获取了一个新的值,那么为了保证这个值的唯一性,这个时候就体现了位运算的重要作用. 位运算可以确保枚举值组合的唯一性. 因为位运算的计算方式是将二进制转换成十进制,也就是说,枚举值里面存取的是 计算后的十进制值. 打个比方: 通过上面的位运算方式设定好枚举以后,打印出来的枚举值分别是: 1 2 4 8 16 这5个数字,无论你如何组合在一起,也不会产生两个同样的数字. 手工的去创建位运算枚举,还有稍微有点花时间的,好在Apple已经为我们准备的uint.所以,用下面这种方式来初始化一个位运算枚举吧:
多枚举值 赋值方式如下:
判断枚举变量是否包含某个固定的枚举值,使用前需要确保枚举值以及各个组合的唯一性:
也可以随时为枚举变量累加某个值,但是要自己控制不要添加已经加入过的枚举值, 枚举变量的值不会有变动,但这样将会误导阅读代码的人
以上,差不多就介绍完了, 如果有什么疑问,欢迎提问. |
|