ios实现 本地存储 数据持久化

参考网络资源

IOS应用程序采用沙盒原理设计,ios每个应用程序都有自己的3个目录(Document,Library,tmp),互相之间不能访问。
Documents存放应用程序的数据。
Library目录下面还有Preferences和Caches目录,Preferences目录存放应用程序的使用偏好,Caches目录与Documents很相 似可以存放应用程序的数据。
Tmp目录供应用程序存储临时文件。

a.获得应用程序的Documents文件夹。
NSArray* myPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
NSString* myDocPath = [myPaths objectAtIndex:0];
获取文件的完整路径。
- (NSString*)filePath:(NSString*)fileName {
    NSArray* myPaths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString* myDocPath = [myPaths objectAtIndex:0];
    NSString* filePath = [myDocPath stringByAppendingPathComponent:fileName];
    return filePath;
}
b.获取tmp目录
NSString* tempPath = NSTemporaryDirectory();
获取文件的完整路径。
NSString* tempFile = [tempPath stringByAppendingPathComponent:@"properties.plist"];

ios四种树据的持久化存储机制:
1.属性列表, plist 文件
2.对象归档
3.数据库存储(SQLite3)
4.苹果公司提供的持久性工具Core Data。

数据存储格式:plist rtf

在object C中,支持序列化的对象有:
NSArray、NSMutableArray、NSDictionary、NSMutableDictionary、NSData、NSMutableData、NSString、NSMutableString、NSNumber、NSDate

一,属性列表的存储

数据写入文件, 获取存储、读取路径 ,文件保存

1.获取存储、读取路径 

2.属性列表plist,将支持序列化的object C对象add至NSArray或NSDictionary中,然后调用这两个对象的writeToFile方法。

属性列表方法的缺点是不能将自定义的对象持久化,因为自定义对象不支持序列化。

NSMutableArray* data = [[NSMutableArray alloc]init];
    [data addObject:studentNo.text];
    [data addObject:studentName.text];
    [data addObject:studentClass.text];
    [data writeToFile:fileName atomically:YES];

读取:

dataArr = [[NSArray alloc]initWithContentsOfFile:tempFile];

自加读取:

NSString *plistPath = [[NSBundle mainBundle] pathForResource:@"plistdemo" ofType:@"plist"];

NSMutableDictionary *data = [[NSMutableDictionary alloc] initWithContentsOfFile:plistPath]




二,对象归档的存储,待试用
将复杂的对象进行另一种形式的序列化,转化后进行读写操作,归档中用到操作类NSKeyedArchive
实现NSCoding协议
NSCoding协议声明了两个方法: 

-(void)encodeWithCoder:(NSCoder *)aCoder,是将对象写入到文件中。
-(id)initWithCoder:(NSCoder *)aDecoder,是将文件中数据读入到对象中。
实现NSCopying协议
NSCopying协议声明了一个方法: -(id)copyWithZone:(NSZone *)zone ,是将对象复制方法。 


三,sqlite3存储,sql语句
1,添加 libsqlite3.dylib 库
2.打开数据库,创建数据库表,添加数据,执行查找删除,关闭数据库

四,coreData  ,。。。

属性列表  和 sqlite3 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值