NSNumber和NSValue对基础C数据类型的对象化封装
由于Objective-C中常用的数据容器,如NSArray,NSDictionary等,只能处理Objective-C中的对象级别的数据类型,对于C中的很多数据类型,如int,float等,无法直接处理。针对这个问题,Objective-C提供了两种存储数据的对象NSNumber和NSValue,能将C中的基本数据类型,包括数值型和结构体型的数据转化成Objective-C可以处理的对象。
NSNumber和NSValue都能将C中的基本数据类型转化成Objective-C中的对象。
1、基本数据类型和NSValue
①基本数据类型转化成NSValue
NSValue *value = [NSValue valueWithBytes:&result objCType:@encode(int)];
其中,result是基本数据的值,int是我们要转化的基本数据类型
②NSValue转化成基本数据类型
[value getValue:&result];
其中,value是一个NSValue类型的对象,result是一个已知的类型的基本数据类型。经过这样的转化,NSValue中保存的数值就放到了result中了。
2、基本数据类型和NSNumber
NSNumber是NSValue的子类,它的出现我理解的就是更加方便了除结构体以外的C中的基本数据类型和Objective-C中对象的相互转化,NSNumber本身提供了很多类方法和实例方法,可以完成这些操作。
①基本数据类型转化成NSNumber
NSNumber *number = [NSNumber numberWithInt:3];
这样就将int型的数据转化成了NSNumber
②NSNumber转化成基本数据类型
NSInteger result = [number integerValue];
同样十分方便,就取出了NSNumber中保存的数值。
3、NSInteger
在这里顺便提一句NSInteger吧,这是一个有符号型int,它与int的区别就在于NSInteger可以自动识别机器是32位还是64位。官方文档是这样写的:
#if __LP64__ || TARGET_OS_EMBEDDED || TARGET_OS_IPHONE || TARGET_OS_WIN32 || NS_BUILD_32_LIKE_64 typedef long NSInteger; #else typedef int NSInteger; #endif
另外,NSInteger的无符号版本是NSUInteger,官方文档中如是定义:
#if __LP64__ || TARGET_OS_EMBEDDED || TARGET_OS_IPHONE || TARGET_OS_WIN32 || NS_BUILD_32_LIKE_64 typedef unsigned long NSUInteger; #else typedef unsigned int NSUInteger; #endif