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

 

1
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

 

1
NSNumber    *number = [NSNumber numberWithInt:3];

  

这样就将int型的数据转化成了NSNumber

 

②NSNumber转化成基本数据类型

1
NSInteger   result = [number integerValue];

  

同样十分方便,就取出了NSNumber中保存的数值。

 

3、NSInteger

在这里顺便提一句NSInteger吧,这是一个有符号型int,它与int的区别就在于NSInteger可以自动识别机器是32位还是64位。官方文档是这样写的:

 

1
2
3
4
5
#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,官方文档中如是定义:

1
2
3
4
5
#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 @   Deric  阅读(231)  评论(0编辑  收藏  举报
编辑推荐:
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
阅读排行:
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用
点击右上角即可分享
微信分享提示