#import <Foundation/Foundation.h>

@interface Student : NSObject <NSCoding>;
@property(nonatomic,strong)NSString* name;
@property(nonatomic,assign)int age;
@property(nonatomic,copy)NSString* tel; -(id)initWithName:(NSString*)name endAge:(int)age endTel:(NSString*)tel; @end #import "Student.h" @implementation Student
@synthesize name=_name,tel=_tel,age=_age;
-(id)initWithName:(NSString *)name endAge:(int)age endTel:(NSString *)tel
{
if (self=[super init]) {
self.name=name;
self.age=age;
self.tel=tel;
}
return self;
} -(void)encodeWithCoder:(NSCoder *)aCoder
{
NSLog(@"编码中。。。。");
[aCoder encodeObject:self.name forKey:@"name"];
[aCoder encodeInt:self.age forKey:@"age"];
[aCoder encodeObject:self.tel forKey:@"tel"];
// [aCoder encodeValueOfObjCType:@"" at:<#(const void *)#>] }
-(id)initWithCoder:(NSCoder *)aDecoder
{
NSLog(@"解码中。。。。");
self=[self initWithName:[aDecoder decodeObjectForKey:@"name"] endAge:[aDecoder decodeIntForKey:@"age"] endTel:[aDecoder decodeObjectForKey:@"tel"]]; return self;
} @end #import "ViewController.h"
#import "Student.h"
@interface ViewController ()
{
UITextField* _tf1;
UITextField* _tf2;
UITextField* _tf3;
}
@end @implementation ViewController - (void)viewDidLoad {
[super viewDidLoad];
[self encodeStu]; // Do any additional setup after loading the view, typically from a nib.
// Dispose of any resources that can be recreated
_tf1=[[UITextField alloc]initWithFrame:CGRectMake(, , , )]; _tf2=[[UITextField alloc]initWithFrame:CGRectMake(, , , )];
_tf2.keyboardType=UIKeyboardTypeDecimalPad; _tf3=[[UITextField alloc]initWithFrame:CGRectMake(, , , )]; _tf1.borderStyle=UITextBorderStyleRoundedRect;
_tf2.borderStyle=UITextBorderStyleRoundedRect;
_tf3.borderStyle=UITextBorderStyleRoundedRect;
[self.view addSubview:_tf1];
[self.view addSubview:_tf2];
[self.view addSubview:_tf3]; //进入后台,触发写文件方法,
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(write) name:UIApplicationDidEnterBackgroundNotification object:nil ];
//进入应用时触发
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(reade) name:UIApplicationDidBecomeActiveNotification object:nil ]; NSDictionary* dic=[[NSDictionary alloc]initWithObjectsAndKeys:@"name",@"xxx",@"age",@"",@"tel",@"", nil];
NSLog(@"%@",[dic objectForKey:@""]);
}
-(void)reade{
//读取文件路径
NSString * path = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:]stringByAppendingPathComponent:@"writefile.text" ];
NSLog(@"read path :%@",path);
NSArray* arr=[NSArray arrayWithContentsOfFile:path];
_tf1.text=arr[];
_tf2.text=arr[];
_tf3.text=arr[]; } -(void)viewWillAppear:(BOOL)animated
{ } -(void)write{
NSString * path=[[NSBundle mainBundle]bundlePath]; //path是文件夹,那么就再加上文件名才是文件完整路径
NSString* path2=[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES) objectAtIndex:];
// path2 = [path stringByAppendingString:@"/writefiles.tet"];
path2= [path2 stringByAppendingPathComponent:@"writefile.text"]; NSLog(@"%@,%@",path,path2);
NSArray* writeArr=@[_tf1.text,_tf2.text,_tf3.text]; [writeArr writeToFile:path2 atomically:YES]; } //归档解决自定义对象
//数据持久化本质:保持状态跟数据 //归档调用,加密写入文件
-(void)loadView
{
[super loadView]; //从程序输入数据 并构建自定义对象(初始化要归档的对象,是数据的生成) Student* stu=[[Student alloc]initWithName:@"啊城" endAge: endTel:@""];
// NSArray* stu=[[NSArray alloc]initWithObjects:@"sss",@"aaaa",@"222", nil];
NSMutableData* data=[[NSMutableData alloc]init];
//构建归档器
NSKeyedArchiver* archiver=[[NSKeyedArchiver alloc]initForWritingWithMutableData:data];
//归档 没有储存动作,只负责编码
[archiver encodeObject:stu forKey:@"stu"];
//千万不能忘记,归档完毕马上调用
[archiver finishEncoding]; //写入文档
[data writeToFile:[[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:]stringByAppendingPathComponent:@"bba1.text" ] atomically:YES];
NSLog(@"111 Stu name is %@,gender is %d,tel is %@",stu.name,stu.age,stu.tel);
}
//解档
-(void)encodeStu{
//取数据,以待解码归档,注意一定要用NSDocumentDirectory
NSData* data= [NSData dataWithContentsOfFile:[[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) objectAtIndex:]stringByAppendingPathComponent:@"bba1.text" ]];
//解档器
NSKeyedUnarchiver* uA=[[NSKeyedUnarchiver alloc]initForReadingWithData:data];
//解档->还原对象,注意解档和键需要和归档一致
Student* stu=[uA decodeObjectForKey:@"stu"];
//解码器,中decodeObjectForKay方法,在解码过程中,会调用initWithCoder方法,并通过对象类型到类中调用已重写实现的initWithCoder方法 NSLog(@"2222 Stu name is %@,gender is %d,tel is %@",stu.name,stu.age,stu.tel);
//
[uA finishDecoding]; } -(void)dealloc{
[[NSNotificationCenter defaultCenter] removeObserver:self name:UIApplicationDidBecomeActiveNotification object:nil];
} - (void)didReceiveMemoryWarning {
[super didReceiveMemoryWarning]; } @end

IOS s数据存储之归档解档的更多相关文章

  1. IOS数据存储之归档/解档

    前言: 前天学习了NSUserDefaults,我们知道NSUserDefaults不能保存自定义对象,所以我们今天来认识一下归档(NSKeyedArchiver)和解档(NSKeyedUnarchi ...

  2. 数据存储之归档解档 NSKeyedArchiver NSKeyedUnarchiver

    在构建应用程序时,有一个重要的问题是如何在每次启动之间持久化数据,以便重现最后一次关闭应用前的状态.在iOS和OS X上,苹果提供了三种选择:Core Data.属性列表(Property List) ...

  3. iOS开发UI篇—ios应用数据存储方式(归档)

    iOS开发UI篇—ios应用数据存储方式(归档)  一.简单说明 在使用plist进行数据存储和读取,只适用于系统自带的一些常用类型才能用,且必须先获取路径相对麻烦: 偏好设置(将所有的东西都保存在同 ...

  4. iOS开发UI篇—ios应用数据存储方式(归档) :转发

    本文转发至:文顶顶http://www.cnblogs.com/wendingding/p/3775293.html iOS开发UI篇—ios应用数据存储方式(归档)  一.简单说明 在使用plist ...

  5. ios应用数据存储方式(归档) - 转

    一.简单说明  1.在使用plist进行数据存储和读取,只适用于系统自带的一些常用类型才能用,且必须先获取路径相对麻烦.  2.偏好设置(将所有的东西都保存在同一个文件夹下面,且主要用于存储应用的设置 ...

  6. 数据持久化------Archiving(归档,解档)

    其中TRPerson为自定义的继承自NSObject的类的子类  其中有两个属性,name 和 age .h文件 #import @interface TRPerson : NSObject<& ...

  7. iOS开发——UI进阶篇(十一)应用沙盒,归档,解档,偏好设置,plist存储,NSData,自定义对象归档解档

    1.iOS应用数据存储的常用方式XML属性列表(plist)归档Preference(偏好设置)NSKeyedArchiver归档(NSCoding)SQLite3 Core Data 2.应用沙盒每 ...

  8. iOS开发中的4种数据持久化方式【一、属性列表与归档解档】

    iOS中的永久存储,也就是在关机重新启动设备,或者关闭应用时,不会丢失数据.在实际开发应用时,往往需要持久存储数据的,这样用户才能在对应用进行操作后,再次启动能看到自己更改的结果与痕迹.ios开发中, ...

  9. iOS 浅复制、深复制、完全复制的知识点梳理验证(附加归档解档)

    在之前转载的一片文章中,文中对浅复制和深复制进行了详细的解读,同时还提到了深复制(one-level-deep copy).完全复制(true copy)的概念,并指出iOS开发中的深复制是单层深赋值 ...

随机推荐

  1. RMAN_学习笔记1_RMAN Structure概述和体系结构

    2014-12-23 Created By BaoXinjian

  2. Hololens开发笔记之Gesture手势识别(手势检测反馈)

    本文实现当使用者手出现在Hololens视野范围内时,跟踪手并给出反馈的效果. 1.在Manager上添加HandsManager脚本组件,用于追踪识别手 HandsManager.cs如下(直接使用 ...

  3. python的json模块

    Python JSON 本章节我们将为大家介绍如何使用 Python 语言来编码和解码 JSON 对象. 环境配置 在使用 Python 编码或解码 JSON 数据前,我们需要先安装 JSON 模块. ...

  4. SecureCRT 连接后一些会话选项配置修改

  5. 19. Palindrome Partitioning && Palindrome Partitioning II (回文分割)

    Palindrome Partitioning Given a string s, partition s such that every substring of the partition is ...

  6. 神奇的C语言

    当然下面列出来的几点都是C的基础用法,只不过是这些用法可能平时不会被注意.所以很多东西第一次看到的时候,可能会觉得很怪异,但是细细想想就能很好的理解,也就能更好的清楚C语言的一些特性.但是在具体的编码 ...

  7. 关于UIView的autoresizingMask属性的研究【转】

    在 UIView 中有一个autoresizingMask的属性,它对应的是一个枚举的值(如下),属性的意思就是自动调整子控件与父控件中间的位置,宽高. 1 2 3 4 5 6 7 8 9 enum  ...

  8. JS-改变页面的颜色(二)

    需求:点击页面的按钮,改变页面的颜色 思路:一先画出最简单的页面,二想办法获取页面的body节点,三想办法修改body节点的背景颜色属性,四通过一个方法获取随机的颜色值           和第一个例 ...

  9. 路由器WDS实际案例

    背景环境: 我家在农村,由于是农村,虽然现在村里迁了网线,但是用户毕竟还是很少的,我家常年都在外面打工,就过年过节回来十几二十天,想上网,不值得迁网线,所以选择不道德的蹭网. 由于手机的信号并没有专业 ...

  10. java学习第四天

    那些逻辑语言就基本了解下,今天想到了一个问题就是关于for和while的区别,从专业上来说,for和while基本上是相同的,但是for是只允许一次访问的,如果结束后就无法继续访问,而while则可以 ...