iOS 关于枚举的使用
2016-03-24 11:10
405 查看
引言:
枚举值 它是一个整形(int) 并且,它不参与内存的占用和释放,枚举定义变量即可直接使用,不用初始化.
在代码中使用枚举的目的只有一个,那就是增加代码的可读性.
使用:
枚举的定义如下:
[csharp] view
plain copy
typedef enum
{
//以下是枚举成员
TestA = 0,
TestB,
TestC,
TestD
}Test;//枚举名称
亦可以如下定义(推荐:结构比较清晰):
[csharp] view
plain copy
typedef NS_ENUM(NSInteger, Test1)
{
//以下是枚举成员
Test1A = 0,
Test1B = 1,
Test1C = 2,
Test1D = 3
};
枚举的定义还支持位运算的方式定义,如下:
等于号后面必须等于1
[csharp] view
plain copy
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个数字,无论你如何组合在一起,也不会产生两个同样的数字.
手工的去创建位运算枚举,还有稍微有点花时间的,好在Apple已经为我们准备的uint.所以,用下面这种方式来初始化一个位运算枚举吧:
[csharp] view
plain copy
typedef NS_ENUM(uint, Test)
{
TestA,
TestB,
TestC,
TestD,
TestE
};
多枚举值 赋值方式如下:
[csharp] view
plain copy
Test tes = (TestA|TestB);
判断枚举变量是否包含某个固定的枚举值,使用前需要确保枚举值以及各个组合的唯一性:
[csharp] view
plain copy
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
也可以随时为枚举变量累加某个值,但是要自己控制不要添加已经加入过的枚举值, 枚举变量的值不会有变动,但这样将会误导阅读代码的人
[csharp] view
plain copy
tes |=TestC;
有累加,自然有累减了,如果累减不存在的枚举值, 那么本次累减的枚举值,会自动累加上去.
[csharp] view
plain copy
tes^= TestE;
以上,差不多就介绍完了, 如果有什么疑问,欢迎提问.
枚举值 它是一个整形(int) 并且,它不参与内存的占用和释放,枚举定义变量即可直接使用,不用初始化.
在代码中使用枚举的目的只有一个,那就是增加代码的可读性.
使用:
枚举的定义如下:
[csharp] view
plain copy
typedef enum
{
//以下是枚举成员
TestA = 0,
TestB,
TestC,
TestD
}Test;//枚举名称
亦可以如下定义(推荐:结构比较清晰):
[csharp] view
plain copy
typedef NS_ENUM(NSInteger, Test1)
{
//以下是枚举成员
Test1A = 0,
Test1B = 1,
Test1C = 2,
Test1D = 3
};
枚举的定义还支持位运算的方式定义,如下:
等于号后面必须等于1
[csharp] view
plain copy
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个数字,无论你如何组合在一起,也不会产生两个同样的数字.
手工的去创建位运算枚举,还有稍微有点花时间的,好在Apple已经为我们准备的uint.所以,用下面这种方式来初始化一个位运算枚举吧:
[csharp] view
plain copy
typedef NS_ENUM(uint, Test)
{
TestA,
TestB,
TestC,
TestD,
TestE
};
多枚举值 赋值方式如下:
[csharp] view
plain copy
Test tes = (TestA|TestB);
判断枚举变量是否包含某个固定的枚举值,使用前需要确保枚举值以及各个组合的唯一性:
[csharp] view
plain copy
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
也可以随时为枚举变量累加某个值,但是要自己控制不要添加已经加入过的枚举值, 枚举变量的值不会有变动,但这样将会误导阅读代码的人
[csharp] view
plain copy
tes |=TestC;
有累加,自然有累减了,如果累减不存在的枚举值, 那么本次累减的枚举值,会自动累加上去.
[csharp] view
plain copy
tes^= TestE;
以上,差不多就介绍完了, 如果有什么疑问,欢迎提问.
相关文章推荐
- iOS : CABasicAnimation
- iOS 延时执行的方法
- IOS开发之也许你没有发现的奇技
- iOS多线程编程技术之NSThread、Cocoa NSOperation、GCD
- IOS百度地图气泡内容自定义
- iOS 手势冲突问题
- 如何去除tabBar的上横线和navigationBar的下横线
- iOS友盟做第三方登录和分享注意事项
- iOS 核心动画简介
- [置顶] 自定义控件:onDraw 方法实现仿 iOS 的开关效果
- iOS 设置NavigationItem的Title的字体大小和颜色
- iOS常用宏定义
- ios 遍历方式
- iOS海哥开发笔记(开发中如何使用数据持久化)海哥原创,让你对存储知识一目了然
- 集成支付宝钱包支付iOS SDK的方法与经验
- iOS 设置视图的圆角效果
- iOS性能优化:Instruments使用实战
- iOS 点击按钮跳转到指定的TabBar
- iOS:OC的定时器任务方法,延时方法
- iOS开发编码建议与编程经验