枚举值: 它是一个整形(int) ,并且它不参加内存的占用和释放 枚举定义变量即可直接使用,不用初始化
三种类型的枚举
enum在iOS6之前一般我们采用C风格的enum关键字可以定义枚举类型
三种写法:
enum {
A,
B,
C
};
enum Name {
A,
B,
C
};
typedef enum {
A,
B,
C
}Name;
默认A=0,B=1,C=2,也可自行赋值
在iOS6之后引入两个宏来定义枚举实际上是将enum定义和typedef合二为一,并且采用不同的宏来从代码角度来区分。
NS_ENUM普通枚举定义可参见UIKit.Framework中
NS_OPTIONS位运算及特殊枚举的定义。什么时候要用到这种方式呢? 那就是一个枚举变量可能要代表多个枚举值的时候. 其实给一个枚举变量赋予多个枚举值的时候,原理只是把各个枚举值加起来罢了. 当加起来以后,就获取了一个新的值,那么为了保证这个值的唯一性,这个时候就体现了位运算的重要作用. 位运算可以确保枚举值组合的唯一性. 因为位运算的计算方式是将二进制转换成十进制,也就是说,枚举值里面存取的是 计算后的十进制值. 打个比方: 通过上面的位运算方式设定好枚举以后,打印出来的枚举值分别是: 1 2 4 8 16 这5个数字,无论你如何组合在一起,也不会产生两个同样的数字.
这两个宏的定义在Foundation.framework的NSObjCRuntime.h中:
#if (__cplusplus && __cplusplus >= 201103L && (__has_extension(cxx_strong_enums) || __has_feature(objc_fixed_enum))) || (!__cplusplus && __has_feature(objc_fixed_enum))
#define NS_ENUM(_type, _name) enum _name : _type _name; enum _name : _type
#if (__cplusplus)
#define NS_OPTIONS(_type, _name) _type _name; enum : _type
#else
#define NS_OPTIONS(_type, _name) enum _name : _type _name; enum _name : _type
#endif
#else
#define NS_ENUM(_type, _name) _type _name; enum
#define NS_OPTIONS(_type, _name) _type _name; enum
#endif
两种写法:
typedef NS_ENUM(NSInteger, Age) {
A,
B,
C
};
//"<<"左移 ,">>"右移
typedef NS_OPTIONS(NSInteger, Age) {
A = 1,
B = 1 << 1,
C = 1 << 1,
D = 1 << 1
};
A=1,B=2(1左移一位),C=4(1左移两位),D=8(1左移三位),其实就是将二进制000001,进行位移操作,再将二进制转换成10进制
当然枚举值之间还有“与&”“或|”的操作,结果其实就是二进制数比对的结果,不明白的可以看下C中的与、或说明
左移且A=1的情况下,“或”可以理解成两枚举值相加:Age age = (A | B); age = 3,“与”可以理解为是否包含某个值 int x = (age & A),int y = (age & C),包含:结果为被包含的值x=A,不包含:结果为0,y=0,即为假;有累加,自然有累减,如果减一个不存在的枚举值, 那么本次累减的枚举值,会自动累加上去,age ^= C,结果为age+C的值,如果减的枚举值存在,则正常相减,age ^= A,结果为age-A的值