NSNumber和NSValue对基础C数据类型的对象化封装(转载)

NSNumber和NSValue对基础C数据类型的对象化封装

 

作者:wangzz
转载请注明出处
如果觉得文章对你有所帮助,请通过留言或关注微信公众帐号wangzzstrive来支持我,谢谢!
 

由于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  

  

posted @ 2015-08-21 17:13  Deric  阅读(227)  评论(0编辑  收藏  举报