iOS数据存款和储蓄之归档

在上一篇的篇章中本身归纳介绍了动用偏幸设置和总体性列表进行数据存款和储蓄iOS数据存款和储蓄之偏疼设置和性质列表,明日总结下多少存款和储蓄之归档的简要利用。归档是一种很常用的公文积攒方法,差不离任何类型的目的都可以被归档积累(实际上是一种文件保留的样式),与天性列表相反,同样作为轻量级存款和储蓄的漫长化方案,数据归档是开展加密管理的,数据在通过归档管理会调换来二进制数据,所以安全性要远远超过属性列表。大家能够将复杂的目的写入文件中,並且不管添扩张少对象,将对象写入磁盘的办法都以一模二样的。搜集了英特网的一部分资料并构成本身的一对经历,以下将从三个地点粗略介绍下归档的选用:

iOS 归档的记录

原稿地址:http://www.cnblogs.com/ios8/p/ios-archive.html

一、使用archiveRootObject实行简易的存档

行使NSKeyedArichiver进行归档、NSKeyedUnarchiver进行接档,这种方式会在写入、读出多少此前对数据开展种类化、反体系化操作。

一、使用archiveRootObject举办简易的存档

行使NSKeyedArichiver进行归档、NSKeyedUnarchiver进行接档,这种措施会在写入、读出多少之前对数据开展体系化、反类别化操作。

  • 归档:

    //1.获取文件路径NSString *docPath=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0];//2、添加储存的文件名NSString *path = [docPath stringByAppendingPathComponent:@"data.archiver"];//3、将一个对象保存到文件中BOOL flag = [NSKeyedArchiver archiveRootObject:@”name” toFile:path]; 
    

这种措施得以对字符串、数字等开展归档,当然也得以对NSArray与NSDictionary进行归档。再次来到值Flag标识着是还是不是归档成功,YES为成功,NO为失利。

  • 解档//1.获取文件路线NSString
    *docPath=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,
    NSUserDomainMask, YES) objectAtIndex:0];NSString *path=[docPath
    stringByAppendingPathComponent:@”data.archiver”];NSLog(@”path=%@”,path);//2.从文件中读取对象[NSKeyedUnarchiver
    unarchiveObjectWithFile:path]

选择NSKeyedUnarchiver进行接档。这种归档的办法存在几个劣点:只可以把叁个目的归档进叁个文本中,那么怎么对多少个对象进行归档呢?

归档是一种很常用的公文储存方法,大致任何类型的对象都能够被归档储存(实际上是一种文件保留的样式),浏览网络的有的素材后,并结成本人的局地经验,总计成此文。

iOS 归档的笔录

归档:

NSString *homeDictionary = NSHomeDirectory();//获取根目录  
NSString *homePath  = [homeDictionary stringByAppendingPathComponent:@"atany.archiver"];//添加储存的文件名  
BOOL flag = [NSKeyedArchiver archiveRootObject:@”归档” toFile:homePath];//归档一个字符串  

这种艺术能够对字符串、数字等开展归档,当然也足以对NSArray与NSDictionary举办归档。重返值Flag标记着是还是不是归档成功,YES为成功,NO为停业。

二、对五个指标的存档

平等是选择NSKeyedArchiver举办归档,分裂的是同时归档几个目的,这里大家比如放入了三个CGPoint点、字符串、整数(当然比较多品种都得以的,譬如UIImage、float等等),使用encodeObject:(nullable
id)objv forKey:(NSString
*)key方法开展归档,最后经过writeToFile方法写入文件。

  • 归档:写入数据//计划数据CGPoint point = CGPointMake;NSString
    *origin = @”坐标原点”;NSInteger value = 10;NSString
    *docPath=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,
    NSUserDomainMask, YES) objectAtIndex:0];NSString *path = [docPath
    stringByAppendingPathComponent:@”multi.archiver”];NSMutableData
    *data = [[NSMutableData alloc] init];NSKeyedArchiver *archvier
    = [[NSKeyedArchiver alloc]
    initForWritingWithMutableData:data];//对多个对象实行归档[archvier
    encodeCGPoint:point forKey:@”kPoint”];[archvier encodeObject:
    origin forKey:@”kOrigin”];[archvier encodeInteger:value
    forKey:@”kValue”];[archvier finishEncoding];[data
    writeToFile:path atomically:YES];

  • 解档:从路线中获取数量构造NSKeyedUnarchiver实例,使用encodeObject:
    forKey:方法取得文件中的对象。NSMutableData *dataR =
    [[NSMutableData alloc]
    initWithContentsOfFile:multiHomePath];NSKeyedUnarchiver
    *unarchiver = [[NSKeyedUnarchiver alloc]
    initForReadingWithData:dateR];CGPoint pointR = [unarchiver
    decodeCGPointForKey:@”kPoint”];NSString *infoR = [unarchiver
    decodeObjectForKey:@”kInfo”];NSInteger valueR = [unarchiver
    decodeIntegerForKey:@”kValue”];[unarchiver
    finishDecoding];NSLog(@”%f,%f,%@,%d”,pointR.x,pointR.y,infoR,valueR);

能够看到对五个指标开展归档照旧挺方便的,这里又并发一个标题,这里的靶子都以着力项目数据,那么怎么对和煦定义类生成的实例对象开展归档呢?

一、使用archiveRootObject进行轻巧的存档

归档是一种很常用的文书积存方法,大致任何项目标目的都可以被归档积累(实际上是一种文件保留的花样),浏览网络的局地资料后,并组成本人的片段经验,计算成此文。

解档:

[NSKeyedUnarchiver unarchiveObjectWithFile:homePath]  ````
使用NSKeyedUnarchiver进行接档(反序列化)。
这种归档的方式存在一个缺点:只能把一个对象归档进一个文件中,那么怎么对多个对象进行归档呢?

## 二、对多个对象的归档
同样是使用NSKeyedArchiver进行归档,不同的是同时归档多个对象,这里我们举例放入了一个CGPoint点、字符串、整数(当然很多类型都可以的,例如UIImage、float等等),使用encodeXXX方法进行归档,最后通过writeToFile方法写入文件。
### 归档:写入数据

//准备数据
CGPoint point = CGPointMake(1.0, 2.0);
NSString *info = @”坐标原点”;
NSInteger value = 10;
NSString *multiHomePath = [NSHomeDirectory()
stringByAppendingPathComponent:@”multi.archiver”];
NSMutableData *data = [[NSMutableData alloc]init];
NSKeyedArchiver *archvier = [[NSKeyedArchiver
alloc]initForWritingWithMutableData:data];

//对三个对象进行归档
[archvier encodeCGPoint:point forKey:@”kPoint”];
[archvier encodeObject:info forKey:@”kInfo”];
[archvier encodeInteger:value forKey:@”kValue”];
[archvier finishEncoding];
[data writeToFile:multiHomePath atomically:YES];

### 接档:
从路径中获得数据构造NSKeyedUnarchiver实例,使用decodeXXXForKey方法获得文件中的对象。

NSMutableData *dataR = [[NSMutableData
alloc]initWithContentsOfFile:multiHomePath];
NSKeyedUnarchiver *unarchiver = [[NSKeyedUnarchiver
alloc]initForReadingWithData:dateR];
CGPoint pointR = [unarchiver decodeCGPointForKey:@”kPoint”];
NSString *infoR = [unarchiver decodeObjectForKey:@”kInfo”];
NSInteger valueR = [unarchiver decodeIntegerForKey:@”kValue”];
[unarchiver finishDecoding];
NSLog(@”%f,%f,%@,%d”,pointR.x,pointR.y,infoR,valueR);

可以看出对多个对象进行归档还是挺方便的,这里又出现一个问题,这里的对象都是基本类型数据,那么怎么对自己定义类生成的实例对象进行归档呢?

## 三、对自定义对象进行归档
 自定义对象,应用范围很广,因为它对应着MVC中的Model层,即实体类。在程序中,我们会在Model层定义很多的entity,例如User,Teacher。。
那么对自定义对象的归档显得重要的多,因为很多情况下我们需要在Home键之后保存数据,在程序恢复时重新加载,那么,归档便是一个好的选择。
首先我们需要,自定义一个实体类,Archive。

*Archive.h*
三、对自定义对象开展归档
// YYViewController.m#import "YYViewController.h"#import "YYPerson.h"@interface YYViewController ()- saveBtnOnclick:sender;- readBtnOnclick:sender;@end@implementation YYViewController- viewDidLoad{ [super viewDidLoad];}- saveBtnOnclick:sender { //1.创建对象 YYPerson *person = [[YYPerson alloc] init]; person.name=@"蜗牛"; person.age=23; person.height=1.83; //2.获取文件路径 NSString *docPath=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]; NSString *path=[docPath stringByAppendingPathComponent:@"person.archiver"]; NSLog(@"path=%@",path); //3.将自定义的对象保存到文件中,调用NSKeyedArchiver的工厂方法 archiveRootObject: toFile: 方法 [NSKeyedArchiver archiveRootObject:p toFile:path];}- readBtnOnclick:sender { //1.获取文件路径 NSString *docPath=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)lastObject]; NSString *path=[docPath stringByAppendingPathComponent:@"person.archiver"]; NSLog(@"path=%@",path); //2.从文件中读取对象,解档对象就调用NSKeyedUnarchiver的一个工厂方法 unarchiveObjectWithFile: 即可。 YYPerson * person = [NSKeyedUnarchiver unarchiveObjectWithFile:path]; if  { NSLog(@"%@,%d,%.1f", person.name, person.age, person.height); } }@end

YYPerson.h

// YYPerson.h#import <Foundation/Foundation.h>// 如果想将一个自定义对象保存到文件中必须实现NSCoding协议@interface YYPerson : NSObject<NSCoding>//姓名@property(nonatomic,copy)NSString *name;//年龄@property(nonatomic,assign)int age;//身高@property(nonatomic,assign)double height;@end

YYPerson.m

// YYPerson.m#import "YYPerson.h"@implementation YYPerson// 当将一个自定义对象保存到文件的时候就会调用该方法// 在该方法中说明如何存储自定义对象的属性// 也就说在该方法中说清楚存储自定义对象的哪些属性- encodeWithCoder:(NSCoder *)aCoder{ NSLog(@"调用了encodeWithCoder:方法"); [aCoder encodeObject:self.name forKey:@"name"]; [aCoder encodeInteger:self.age forKey:@"age"]; [aCoder encodeDouble:self.height forKey:@"height"];}// 当从文件中读取一个对象的时候就会调用该方法// 在该方法中说明如何读取保存在文件中的对象// 也就是说在该方法中说清楚怎么读取文件中的对象- initWithCoder:(NSCoder *)aDecoder{ NSLog(@"调用了initWithCoder:方法"); //注意:在构造方法中需要先初始化父类的方法 if (self=[super init]) { self.name=[aDecoder decodeObjectForKey:@"name"]; self.age=[aDecoder decodeIntegerForKey:@"age"]; self.height=[aDecoder decodeDoubleForKey:@"height"]; } return self;}@end

应用NSKeyedArichiver进行归档、NSKeyedUnarchiver实行接档,这种措施会在写入、读出多少此前对数据开展体系化、反种类化操作。

一、使用archiveRootObject实行简易的存档

import <Foundation/Foundation.h>

@interface Archive : NSObject
@property (copy,nonatomic) NSString *name;
@property NSInteger age;
@property (copy,nonatomic) NSString *address;
@property (copy,nonatomic) UIImage *photo;

@end

*Archive.m*
注意
  • 若是须要归档的类是某些自定义类的子类时,就供给在归档和平消除档在此以前先达成父类的存档和平解决档方法。即
    [super encodeWithCoder:aCoder] 和 [super initWithCoder:aDecoder]
    方法;
  • 不能不及照并落到实处NSCoding公约
  • 归档和平消除归档当中专擅对象都急需归档和解归档整个文件
  • 归档后的文书是加密的,保存文件的扩大名能够随意钦点

归档:

应用NSKeyedArichiver进行归档、NSKeyedUnarchiver进行接档,这种办法会在写入、读出多少在此之前对数码开展系列化、反连串化操作。

import “Archive.h”

上边分享一个品种中封装的依附归档创立的二个用来地点数据存款和储蓄的类如下:
// LocalArchiverManager.h 文件#import <Foundation/Foundation.h>@interface LocalArchiverManager : NSObject/**单例模式,获取请求管理类 *\param param: 无 *\returns return: 无 */+ (LocalArchiverManager *)shareManagement;/**清除本地的序列化的文件 *\param param: 无 *\returns return: 无 */- clearArchiverData;/**保存缓存数据 *\param obj: 数据源 *\param key: 接口的名称 *\returns 无 */- saveDataArchiver:obj andAPIKey:(NSString *)key;/**回去缓存数据 *\param obj: api的key *\returns id: 返回的数据源 */- archiverQueryAPIKey:(NSString *)key;@end

LocalArchiverManager.m 文件

#import "LocalArchiverManager.h"#define Document [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:0]#define ArchiverFile [Document stringByAppendingPathComponent:@"Archiver"]@interface LocalArchiverManager()@property(nonatomic, strong) NSFileManager *fileManager;@end@implementation LocalArchiverManager+ (LocalArchiverManager *)shareManagement{ LocalArchiverManager *m_localArchiverMana = nil; static dispatch_once_t onceTocken; dispatch_once(&onceTocken, ^ { m_localArchiverMana = [[LocalArchiverManager alloc] init]; }); return m_localArchiverMana;}- init{ self = [super init]; if { self.fileManager = [NSFileManager defaultManager]; } return self;}#pragma mark private methods// 检测path路径文件是否存在- checkPathIsExist:(NSString *)path{ return [_fileManager fileExistsAtPath:path isDirectory:nil];}// 创建文件- createArchiverFile{ if (![self checkPathIsExist:ArchiverFile]) { [self addNewFolder:ArchiverFile]; }}//新建目录,path为目录路径- addNewFolder:(NSString *)path{ [_fileManager createDirectoryAtPath:path withIntermediateDirectories:YES attributes:nil error:nil];}#pragma mark public methods- clearArchiverData{ NSError *error; if([m_fileManager removeItemAtPath:ArchiverFile error:&error]) { } else { DLOG(@"清除本地序列化的文件失败....:%@",error); }}// 保存数据- saveDataArchiver:obj andAPIKey:(NSString *)key{ NSMutableData *data = [[NSMutableData alloc] init]; NSKeyedArchiver *archiver = [[NSKeyedArchiver alloc] initForWritingWithMutableData:data]; [archiver encodeObject:obj forKey:key]; [archiver finishEncoding]; [self createArchiverFile]; key = [key stringByReplacingOccurrencesOfString:@"/" withString:@"_"]; NSString *path = [ArchiverFile stringByAppendingPathComponent:[NSString stringWithFormat:@"%@.text",key]]; BOOL isSuc = [data writeToFile:path atomically:YES];if { DLOG(@"本地序列化失败key....:%@",key); }}// 获取数据- archiverQueryAPIKey:(NSString *)key{ NSString *str = [key stringByReplacingOccurrencesOfString:@"/" withString:@"_"]; NSString *path = [ArchiverFile stringByAppendingPathComponent:[NSString stringWithFormat:@"%@.text",str]]; NSMutableData *data = [[NSMutableData alloc] initWithContentsOfFile:path]; NSKeyedUnarchiver *unarchiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:data]; id content = [unarchiver decodeObjectForKey:key]; [unarchiver finishDecoding]; DLOG(@"content.....:%@",content); return content;}

接待阅读:

  • iOS数据存储之偏爱设置和属性列表

iOS技术沟通群 461069757iOS-Ant-Bang互助社区 426981364 款待参预!

NSString *homeDictionary = NSHomeDirectory();//获取根目录

归档:

define kNameKey @”NameKey”

NSString *homePath  = [homeDictionary stringByAppendingPathComponent:@”atany.archiver”];//增加囤积的文件名

NSString *homeDictionary = NSHomeDirectory();//获取根目录

define kAgeKey @”AgeKey”

BOOLflag = [NSKeyedArchiver archiveRootObject:@”归档” toFile:homePath];//归档一个字符串

NSString *homePath  = [homeDictionary stringByAppendingPathComponent:@”atany.archiver”];//增加仓库储存的公文名

define kAddress @”AddressKey”

这种形式能够对字符串、数字等开展归档,当然也得以对NSArray与NSDictionary进行归档。再次来到值Flag标记着是或不是归档成功,YES为打响,NO为倒闭。

BOOLflag = [NSKeyedArchiver archiveRootObject:@”归档” toFile:homePath];//归档八个字符串

define kPhotoKey @”PhotoKey”

@implementation Archive
@synthesize name = _name;
@synthesize age = _age;
@synthesize address = _address;
@synthesize photo = _photo;

接档:

这种艺术得以对字符串、数字等举行归档,当然也得以对NSArray与NSDictionary进行归档。再次回到值Flag标识着是或不是归档成功,YES为打响,NO为战败。

pragma mark – NSCoding

  • (void)encodeWithCoder:(NSCoder *)aCoder {
    [aCoder encodeObject:_name forKey:kNameKey];
    [aCoder encodeInteger:_age forKey:kAgeKey];
    [aCoder encodeObject:_address forKey:kAddress];
    [aCoder encodeObject:_photo forKey:kPhotoKey];
    }

  • (id)initWithCoder:(NSCoder *)aDecoder {
    if (self = [super init]) {
    _name = [aDecoder decodeObjectForKey:kNameKey];
    _age = [aDecoder decodeIntegerForKey:kAgeKey];
    _address = [aDecoder decodeObjectForKey:kAddress];
    _photo = [aDecoder decodeObjectForKey:kPhotoKey];
    }
    return self;
    }

[NSKeyedUnarchiver unarchiveObjectWithFile:homePath]

接档:

pragma mark – NSCoping

  • (id)copyWithZone:(NSZone *)zone {
    Archive *copy = [[[self class] allocWithZone:zone] init];
    copy.name = [self.name copyWithZone:zone];
    copy.age = self.age;
    copy.address = [self.address copyWithZone:zone];
    copy.photo = self.photo;
    return copy;
    }
    @end

Archive类有四个字段(名字、年纪、地址、头像),除了年纪为整型之外,其他的都看作Object。

【注】:要将一个自定义的类进行归档,那么类里面的每个属性都必须是可以被归档的,如果是不能归档的类型,我们可以把他转化为NSValue进行归档,然后在读出来的时候在转化为相应的类。

Archive实现了三个委托方法1)encodeWithCoder: 2)initWithCoder:  3)copyWithZone:
**1)encodeWithCoder**
Encodes the receiverusing a given archiver
通过一个给定的archiver把消息接收者进行编码。
当接收到encodeObject消息的时候,类终端encodeWithCoder方法被调用。
**2)initWithCoder**
Returns an objectinitialized from data in a given unarchiver. (required)
从一个给定unarchiver的数据中返回一个初始化对象。
**3)copyWithZone**
Returnsa new instance that’s a copy of the receiver
返回消息接收者的一个复制的新实例。
SDK的概念就是这样,下面看看这个自定义类归档的具体代码,其实和多个对象的归档是一样的。。。

### 归档:

//保存图片与归档

  • (IBAction)save:(id)sender {

    //计划数据
    NSString *name = @”演习一下”;
    NSInteger age = 22;
    NSString *address = @”iOS”;
    UIImage *photo = [UIImage imageNamed:@”loginman.jpg”];
    //存款和储蓄数据到类
    Archive *archivingData = [[Archive alloc] init];
    archivingData.name = name;
    archivingData.age = age;
    archivingData.address = address;
    archivingData.photo = photo;

    //归档
    NSMutableData *data = [[NSMutableData alloc] init];
    NSKeyedArchiver *archiver = [[NSKeyedArchiver alloc]
    initForWritingWithMutableData:data];

    [archiver encodeObject:archivingData forKey:kArchivingDataKey]; //
    archivingDate的encodeWithCoder
    艺术被调用
    [archiver finishEncoding];
    //写入文件
    [data writeToFile:self.archivingFilePath atomically:YES];
    }

### 接档:
  • (IBAction)loadArchive:(id)sender {
    NSData *data = [[NSMutableData alloc]
    initWithContentsOfFile:self.archivingFilePath];
    NSKeyedUnarchiver *unarchiver = [[NSKeyedUnarchiver alloc]
    initForReadingWithData:data];

    //获得类
    Archive *archivingData = [unarchiver
    decodeObjectForKey:kArchivingDataKey];// initWithCoder方法被调用
    [unarchiver finishDecoding];

    //读取的数据
    NSString *name = archivingData.name;
    NSInteger age = archivingData.age;
    NSString *address = archivingData.address;
    self.imageView.image = archivingData.photo;
    NSLog(@”%@||%d||%@”,name,age,address);

我们save之后loadArchive一次
打出结果为:
**2016-12-22 19:29:41.743TestArchives[16708:c07]练习一下||22||iOS**
获取成功。

接纳NSKeyedUnarchiver举行接档(反种类化)。

[NSKeyedUnarchiver unarchiveObjectWithFile:homePath]

这种归档的点子存在一个败笔:只可以把三个指标归档进两个文书中,那么怎么对四个对象开展归档呢?

采取NSKeyedUnarchiver进行接档(反体系化)。

二、对多个对象的存档

这种归档的点子存在一个欠缺:只好把一个对象归档进多个文本中,那么怎么对三个指标开展归档呢?

未有差距于是应用NSKeyedArchiver举办归档,分化的是还要归档四个目的,这里大家举例放入了二个CGPoint点、字符串、整数(当然非常多类型都足以的,举例UIImage、float等等),使用encodeXXX方法进行归档,最终通过writeToFile方法写入文件。

二、对三个对象的存档

归档:写入数据

同一是应用NSKeyedArchiver举行归档,分化的是还要归档八个目的,这里大家比如纳入了七个CGPoint点、字符串、整数(当然比相当多连串都得以的,举个例子UIImage、float等等),使用encodeXXX方法进行归档,最终通过writeToFile方法写入文件。

//企图数据

归档:写入数据

CGPoint point = CGPointMake(1.0, 2.0);

//打算数据

NSString *info = @”坐标原点”;

CGPoint point = CGPointMake(1.0, 2.0);

NSInteger value = 10;

NSString *info = @”坐标原点”;

NSString *multiHomePath = [NSHomeDirectory() stringByAppendingPathComponent:@”multi.archiver”];

NSInteger value = 10;

NSMutableData *data = [[NSMutableData alloc]init];

NSString *multiHomePath = [NSHomeDirectory() stringByAppendingPathComponent:@”multi.archiver”];

NSKeyedArchiver *archvier = [[NSKeyedArchiver alloc]initForWritingWithMutableData:data];

NSMutableData *data = [[NSMutableData alloc]init];

//对多少个目标开展归档

NSKeyedArchiver *archvier = [[NSKeyedArchiver alloc]initForWritingWithMutableData:data];

[archvier encodeCGPoint:point forKey:@”kPoint”];

//对七个指标开展归档

[archvier encodeObject:info forKey:@”kInfo”];

[archvier encodeCGPoint:point forKey:@”kPoint”];

[archvier encodeInteger:value forKey:@”kValue”];

[archvier encodeObject:info forKey:@”kInfo”];

[archvier finishEncoding];

[archvier encodeInteger:value forKey:@”kValue”];

[data writeToFile:multiHomePath atomically:YES];

[archvier finishEncoding];

接档:从路线中得到数据构造NSKeyedUnarchiver实例,使用decodeXXXForKey方法获得文件中的对象。

[data writeToFile:multiHomePath atomically:YES];

NSMutableData *dataR = [[NSMutableData alloc]initWithContentsOfFile:multiHomePath];

接档:从路线中获得多少构造NSKeyedUnarchiver实例,使用decodeXXXForKey方法获得文件中的对象。

NSKeyedUnarchiver *unarchiver = [[NSKeyedUnarchiver alloc]initForReadingWithData:dateR];

NSMutableData *dataR = [[NSMutableData alloc]initWithContentsOfFile:multiHomePath];

CGPoint pointR = [unarchiver decodeCGPointForKey:@”kPoint”];

NSKeyedUnarchiver *unarchiver = [[NSKeyedUnarchiver alloc]initForReadingWithData:dateR];

NSString *infoR = [unarchiver decodeObjectForKey:@”kInfo”];

CGPoint pointR = [unarchiver decodeCGPointForKey:@”kPoint”];

NSInteger valueR = [unarchiver decodeIntegerForKey:@”kValue”];

NSString *infoR = [unarchiver decodeObjectForKey:@”kInfo”];

[unarchiver finishDecoding];

NSInteger valueR = [unarchiver decodeIntegerForKey:@”kValue”];

发表评论

电子邮件地址不会被公开。 必填项已用*标注

网站地图xml地图