ios开发 数据存储

原地址:http://blog.csdn.net/sxhong/article/details/8223881

首选项设置存储

NSUserDefaults 以及通过它控制的SettingBundle  NSUserDefaults 用来保存一些设置,他会自动写到何时的位置。
NSUbiquitousKeyValueStore 多平台同步设置,限制是大小64k,开启entitlement,唯一Apple ID(还要考虑无法连接到iCloud网络时的情形)

文件存储
一.目录描述

<Application_Home>/AppName.app bundle目录,包括程序本身。往里面些东西会导致签名改变和重启程序。初始同步后iTunes不备份此目录。
<Application_Home>/Documents/ 存储用户文档和程序数据。通过文件共享可以使其可见。iTunes备份之。
<Application_Home>/Documents/Inbox 其他程序要求本程序打开的文档。可读删,不可增加修改。要改变可以先移出来。iTunes备份之。
<Application_Home>/Library/ 非用户数据文件存储的根目录。用其中标准或自定义的文件夹备份不被用户可见的数据。不应用这个目录存储用户数据。iTunes备份之。
  ~Library/Application Support/<bundle_ID> 为用户创建管理的资源和数据文件。用这个目录存储程序状态信息,下载的文件甚至用户创建但同意你管理的数据。自动保存文件。
  ~/Library/Caches/<bundle_ID> 用来存储缓存文件或者程序可以简单重建的文件的目录。
<Application_Home>/tmp/ 临时文件目录,可能被系统删除,不应期望始终存在。不被iTunes备份。
另:

离线数据
可以下载,或重新创建,但用户希望在离线时也能访问这些数据。存放在<Application_Home>/Documents 或<Application_Home>/Library/Private Documents ,并标记为"do not backup"。这两个位置的数据在低存储空间时都会保留,而"do not backup"属性会阻止iTunes或iCloud备份。应用不再需要离线数据文件时,应该尽快删除,以避免浪费用户的存储空间。设置do not back up属性

  1. #include <sys/xattr.h>
  2. - (BOOL)addSkipBackupAttributeToItemAtURL:(NSURL *)URL
  3. {
  4. const char* filePath = [[URL path] fileSystemRepresentation];
  5. const char* attrName = "com.apple.MobileBackup";
  6. u_int8_t attrValue = 1;
  7. int result = setxattr(filePath, attrName, &attrValue, sizeof(attrValue), 0, 0);
  8. return result == 0;
  9. }

复制代码

得到目录地址
URLsForDirectory:inDomains: method 返回NSURL形式的目录地址
NSSearchPathForDirectoriesInDomains 返回字符串形式的目录地址
NSHomeDirectory 返回程序根目录
NSTemporaryDirectory 返回临时文件目录

相关变量定义

  1. NSSearchPathDirectory
  2. enum {
  3. NSApplicationDirectory = 1,//Supported applications (/Applications)
  4. NSDemoApplicationDirectory,//Unsupported applications and demonstration versions
  5. NSDeveloperApplicationDirectory,//Developer applications (/Developer/Applications)
  6. NSAdminApplicationDirectory,//System and network administration applications
  7. NSLibraryDirectory,//Various user-visible documentation, support, and configuration files (/Library)
  8. NSDeveloperDirectory,//Developer resources (/Developer)
  9. NSUserDirectory,//User home directories (/Users)
  10. NSDocumentationDirectory,//
  11. NSDocumentDirectory,//
  12. NSCoreServiceDirectory,//Location of core services (System/Library/CoreServices)
  13. NSAutosavedInformationDirectory = 11,//Location of user’s autosaved documents Library/Autosave Information
  14. NSDesktopDirectory = 12,//
  15. NSCachesDirectory = 13,//Location of discardable cache files (Library/Caches)
  16. NSApplicationSupportDirectory = 14,//Location of application support files (Library/Application Support)
  17. NSDownloadsDirectory = 15,//
  18. NSInputMethodsDirectory = 16,//
  19. NSMoviesDirectory = 17,//
  20. NSMusicDirectory = 18,//
  21. NSPicturesDirectory = 19,//
  22. NSPrinterDescriptionDirectory = 20,//
  23. NSSharedPublicDirectory = 21,//
  24. NSPreferencePanesDirectory = 22,//
  25. NSItemReplacementDirectory = 99,//
  26. NSAllApplicationsDirectory = 100,//
  27. NSAllLibrariesDirectory = 101//
  28. };
  29. typedef NSUInteger NSSearchPathDirectory;

复制代码

  1. enum {
  2. NSUserDomainMask = 1,//用户主目录中
  3. NSLocalDomainMask = 2,//当前机器中
  4. NSNetworkDomainMask = 4,//网络中可见的主机
  5. NSSystemDomainMask = 8,//系统目录,不可修改(/System)
  6. NSAllDomainsMask = 0x0ffff,//全部
  7. };
  8. typedef NSUInteger NSSearchPathDomainMask;

复制代码

二.存储方式(一).属性列表(plist)
array,dictionary,data,string,NSNumber,NSDate 等ns对象直接写入plist文件中保存.
(二).归档文件
实现NSCoding协议(NSCopy也要实现?没实现也成功了。。)编解码类说明NSKeyedArchiver创建
- (id)initForWritingWithMutableData:(NSMutableData *)data // 归档数据写到data中
归档数据
+ (NSData *)archivedDataWithRootObject:(id)rootObject // 归档到data中
+ (BOOL)archiveRootObject:(id)rootObject toFile:(NSString *)path // 归档到文件中
- (void)finishEncoding // 调用后不能继续归档数据,归档结束必须调用(公共方法归档的不用理这个了)
– outputFormat // data编码方式,xml还是二进制
– setOutputFormat:
编码数据
– encodeBool:forKey:
– encodeBytes:length:forKey:
– encodeConditionalObject:forKey:
– encodeDouble:forKey:
– encodeFloat:forKey:
– encodeInt:forKey:
– encodeInt32:forKey:
– encodeInt64:forKey:
– encodeObject:forKey:
代理委托
– delegate
– setDelegate:

  1. – archiver:didEncodeObject:
  2. – archiverDidFinish:
  3. – archiver:willEncodeObject:
  4. – archiverWillFinish:
  5. – archiver:willReplaceObject:withObject:

复制代码

类和类名
+ setClassName:forClass:
+ classNameForClass:
– setClassName:forClass:
– classNameForClass:
异常
extern NSString *NSInvalidArchiveOperationException;NSKeyedUnarchiver创建
– initForReadingWithData:
取消归档
+ (id)unarchiveObjectWithData:(NSData *)data // 从data中得到实现归档的对象
+ (id)unarchiveObjectWithFile:(NSString *)path // 从文件中得到
解码数据
- (BOOL)containsValueForKey:(NSString *)key // 是否包含给定的key编码对象
– decodeBoolForKey:
– decodeBytesForKey:returnedLength:
– decodeDoubleForKey:
– decodeFloatForKey:
– decodeIntForKey:
– decodeInt32ForKey:
– decodeInt64ForKey:
– decodeObjectForKey:
- (void)finishDecoding // 通知委托解码结束,调用后不能再继续解码
代理委托
– delegate
– setDelegate:

  1. – unarchiver:cannotDecodeObjectOfClassName:originalClasses:
  2. – unarchiver:didDecodeObject:
  3. – unarchiver:willReplaceObject:withObject:
  4. Finishing Decoding
  5. – unarchiverDidFinish:
  6. – unarchiverWillFinish:

复制代码

类名
+ setClass:forClassName:
+ classForClassName:
– setClass:forClassName:
– classForClassName:
异常
NSString *NSInvalidUnarchiveOperationException;
(三).CoreData
xcdatamodeld文件中Entity的三种属性:
Attributes: 对应的Obj-c类的接口变量.
Relationships: Entity之间的关系,to-one,or to-many.
Fetched properties: 对上面Relationship的过滤?参考参考1对应文件存储形式COREDATA_EXTERN NSString * const NSSQLiteStoreType NS_AVAILABLE(10_4, 3_0);// SQLite形式存储
COREDATA_EXTERN NSString * const NSXMLStoreType NS_AVAILABLE(10_4, NA);// ios不可用
COREDATA_EXTERN NSString * const NSBinaryStoreType NS_AVAILABLE(10_4, 3_0);// 二进制形式存储
COREDATA_EXTERN NSString * const NSInMemoryStoreType NS_AVAILABLE(10_4, 3_0);// 内存中基本使用过程(括号中参考sql术语)
NSManagedObjectModel对象 获取工程中xcdatamodeld文件设置的模版(就是你的数据库有哪些表,表中有哪些字段的一种说明)
NSPersistentStoreCoordinator对象 根据上面的模版生成或对应的一个文件(数据库文件,具体的数据文件)
NSManagedObjectContext对象 上面文件的操作的空间,增删改查都通过这里进行
NSEntityDescription对象 得到上面context中的一个表
NSFetchRequest对象 对上面表的一些具体操作,增删改查
- (NSArray *)executeFetchRequest:(NSFetchRequest *)request error:(NSError **)error; 使用这个方法执行上面的request
如果增删改了context,记得保存。结束过程示例:

  1. NSManagedObjectContext *managedObjectContext = nil;
  2. // 得到模版
  3. NSURL *modelURL = [[NSBundle mainBundle] URLForResource:@"YOUR_XCDATAMODELD_FILE_NAME" withExtension:@"momd"];
  4. NSManagedObjectModel* managedObjectModel = [[NSManagedObjectModel alloc] initWithContentsOfURL:modelURL];
  5. // 具体文件,DOCUMENT_DICRECTORY应该是nsurl的..
  6. NSURL *storeURL = [@"DOCUMENT_DICRECTORY" URLByAppendingPathComponent:@"SQLITE.sqlite"];
  7. NSError *error = nil;
  8. NSPersistentStoreCoordinator *coordinator = [[NSPersistentStoreCoordinator alloc] initWithManagedObjectModel:managedObjectModel];
  9. // 使用SQLite存储
  10. if (![coordinator addPersistentStoreWithType:NSSQLiteStoreType configuration:nil URL:storeURL options:nil error:&error]) {
  11. // 出错
  12. }
  13. else
  14. {
  15. // 得到操作空间
  16. managedObjectContext = [[NSManagedObjectContext alloc] init];
  17. [managedObjectContext setPersistentStoreCoordinator:coordinator];
  18. }
  19. // 得到具体的表
  20. NSEntityDescription *entityDescription = [NSEntityDescription
  21. entityForName:@"ONE_ENTITY_NAME"
  22. inManagedObjectContext:managedObjectContext];
  23. // 操作语句
  24. NSFetchRequest *request = [[NSFetchRequest alloc] init];
  25. [request setEntity:entityDescription];
  26. // 操作语句的条件
  27. NSPredicate *pred = [NSPredicate predicateWithFormat:@"PREDICATE_SECTION"];
  28. [request setPredicate:pred];
  29. NSManagedObject *manageObject = nil;
  30. // 执行操作,得到多条具体数据
  31. NSArray *objects = [managedObjectContext executeFetchRequest:request error:&error];
  32. if (objects == nil) {
  33. // 出错
  34. }
  35. if ([objects count] > 0)
  36. // 多条,取第一条
  37. manageObject = [objects objectAtIndex:0];
  38. else
  39. // 没有相应的,就创建
  40. manageObject = [NSEntityDescription
  41. insertNewObjectForEntityForName:@"TABLE_NAME"
  42. inManagedObjectContext:managedObjectContext];
  43. // 改变她的一个字段的值
  44. [manageObject setValue:@"VALUE" forKey:@"ONE_FIELD_NAME_OF_THE_TABLE"];
  45. [request release];
  46. // 保存,结束
  47. [managedObjectContext save:&error];

复制代码

(四).SQLite
引入SQLite库,加入头文件,使用C API操作.繁琐的地方在于只能存储c数据格式,需要来回转换.过程示例:

  1. // 声明数据库
  2. sqlite3 *database;
  3. // 打开
  4. if (sqlite3_open("数据库文件路径", &database) != SQLITE_OK) {
  5. sqlite3_close(database);
  6. // 出错
  7. }
  8. char *errorMsg;
  9. // 执行无返回语句
  10. if (sqlite3_exec (database, "增删改创语句",NULL, NULL, &errorMsg) != SQLITE_OK) {
  11. sqlite3_close(database);
  12. // 出错
  13. }
  14. sqlite3_stmt *statement;
  15. // 执行查询语句
  16. if (sqlite3_prepare_v2(database, "查询语句",-1, &statement, nil) == SQLITE_OK) {
  17. // 遍历结果
  18. while (sqlite3_step(statement) == SQLITE_ROW) {
  19. int row = sqlite3_column_int(statement, 0);
  20. // 第一列数据
  21. char *rowData = (char *)sqlite3_column_text(statement, 1);
  22. }
  23. // 结束遍历
  24. sqlite3_finalize(statement);
  25. }
  26. // 关闭数据库
  27. sqlite3_close(database);
时间: 2024-10-20 11:10:33

ios开发 数据存储的相关文章

IOS开发数据存储篇—IOS中的几种数据存储方式

IOS开发数据存储篇—IOS中的几种数据存储方式 发表于2016/4/5 21:02:09  421人阅读 分类: 数据存储 在项目开发当中,我们经常会对一些数据进行本地缓存处理.离线缓存的数据一般都保存在APP所在的沙盒之中.一般有以下几种: 1.PList(XML属性列表) 在使用plist进行数据存储和读取,只适用于系统自带的一些常用类型才能用,且必须先获取路径相对麻烦 //写入文件 NSString *doc = [NSSearchPathForDirectoriesInDomains(

iOS开发-数据存储NSCoder

软件中永远绕不开的一个问题就是数据存储的问题,PC的时候一般都是选择在数据库中存储,iOS如果是和后端配合的话,那么不需要考虑数据存储的这个问题,上次写了一下plist的存储,不过数据都是存储一些简单的键值对对象.本次需要将一些自己定义的类型存储在plist比如说图片,这个时候可以利用NSCoding协议,将数据地以类似档案的形式存储到plist文件中,然后从plist的文件中读取数据,使用协议的时候这个时候就会用到了NSCoder,如果对存档和解压没有概念的话,可以简单的理解为数据的序列化与反

IOS开发—数据存储(直接写入、NSUserDefaults、NSkeyedArchiver)

数据存储(直接写入.NSUserDefaults.NSkeyedArchiver) ios中常用文件存取的方法有: 1.直接写文件的方式,可以存储的对象有NSString.NSArray.NSDictionary.NSData.NSNumber,数据全部存放在一个属性列表文件(*.plist文件)中. 2.NSUeserDefaults(偏好设置),用来存储应用设置信息,文件放在perference目录下. 3.归档操作(NSkeyedArchiver),不同于前面两种,它可以把自定义对象存放在

IOS开发数据存储篇--FMDB源码分析3(FMDatabaseQueue+FMDatabasePool)

一.前言 如上一章所讲,FMDB源码主要有以下几个文件组成: FMResultSet : 表示FMDatabase执行查询之后的结果集. FMDatabase : 表示一个单独的SQLite数据库操作实例,通过它可以对数据库进行增删改查等等操作. FMDatabaseAdditions : 扩展FMDatabase类,新增对查询结果只返回单个值的方法进行简化,对表.列是否存在,版本号,校验SQL等等功能. FMDatabaseQueue : 使用串行队列 ,对多线程的操作进行了支持. FMDat

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

OS开发UI篇—ios应用数据存储方式(归档)  一.简单说明 在使用plist进行数据存储和读取,只适用于系统自带的一些常用类型才能用,且必须先获取路径相对麻烦: 偏好设置(将所有的东西都保存在同一个文件夹下面,且主要用于存储应用的设置信息) 归档:因为前两者都有一个致命的缺陷,只能存储常用的类型.归档可以实现把自定义的对象存放在文件中. 二.代码示例 1.文件结构 2.代码示例 YYViewController.m文件 1 // 2 // YYViewController.m 3 // 02

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

iOS开发UI篇-ios应用数据存储方式(归档)  一.简单说明 在使用plist进行数据存储和读取,只适用于系统自带的一些常用类型才能用,且必须先获取路径相对麻烦: 偏好设置(将所有的东西都保存在同一个文件夹下面,且主要用于存储应用的设置信息) 归档:因为前两者都有一个致命的缺陷,只能存储常用的类型.归档可以实现把自定义的对象存放在文件中. 二.代码示例 1.文件结构 2.代码示例 YYViewController.m文件 1 // 2 // YYViewController.m 3 // 0

iOS开发UI篇—ios应用数据存储方式(偏好设置)

iOS开发UI篇—ios应用数据存储方式(偏好设置) 一.简单介绍 很多iOS应用都支持偏好设置,比如保存用户名.密码.字体大小等设置,iOS提供了一套标准的解决方案来为应用加入偏好设置功能 每个应用都有个NSUserDefaults实例,通过它来存取偏好设置.比如,保存用户名.字体大小.是否自动登录 存储位置: 存储形式: 二.代码示例 1.storyboard 2.代码 1 // Created by 鑫 on 14-10-24. 2 // Copyright (c) 2014年 梁镋鑫.

iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist

iOS开发UI篇—ios应用数据存储方式(XML属性列表-plist) 一.ios应用常用的数据存储方式 1.plist(XML属性列表归档) 2.偏好设置 3.NSKeydeArchiver归档(存储自定义对象) 4.SQLite3(数据库,关系型数据库,不能直接存储对象,要编写一些数据库的语句,将对象拆开存储) 5.Core Data(对象型的数据库,把内部环节屏蔽) 二.应用沙盒 每个iOS应用都有?己的应?沙盒(应用沙盒就是文件系统目录),与其他文件系统隔离.应?必须待在?己的沙盒里,其

iOS开发 数据缓存-数据库

iOS中数据存储方式 Plist(NSArray\NSDictionary) Preference(偏好设置\NSUserDefaults) NSCoding (NSKeyedArchiver\NSkeyedUnarchiver) SQlite3 Core Date Plist.Preference.NSCoding的存储方式 详见 iOS开发 文件存储方式 数据库的存储方式 Core Date:Core Data是iOS5之后才出现的一个框架,它提供了对象-关系映射(ORM)的功能,即能够将O