一、 User Defaults

1. 是什么?

是一个特殊的plist文件

2. 干什么?

用于保存应用的配置信息

3. 存什么信息?

信息:欢迎界面有没有被打开过

目的:欢迎界面只显示一次

信息:应用程序被打开的次数/使用的时间长度/交互的次数

目的:当应用程序被打开10次后 请求用户对程序打星

信息:数据版本信息

目的:数据迁移

1.0

1|TXT|数据迁移

2.0

2212|26782162|TXT|数据迁移|3278232234562734

信息:默认信息

目的:打开应用程序后 显示默认帐号名

- (void)viewDidLoad

{

[superviewDidLoad];

// 判断用户是否是第一次打开

// 获取用户默认standardUserDefaults

NSUserDefaults *userDefault = [NSUserDefaultsstandardUserDefaults];

BOOL opened = [userDefault boolForKey:@"opened"]; // 获取key值opened

[userDefault setBool:YESforKey:@"opened"]; // 设置key值opened

[userDefault synchronize]; // 同步

}

练习:

使用User Defaults

当程序被打开10次时,弹出UIAlertView

提示用户打星

二、archive归档

plist是对象和plist之间的转换

archive是对象(任何)到NSData的渠道

对象到NSData(归档)步骤:

归档(拆毛衣)

NSObject                    对象         毛衣

NSMutableData     字节         毛线团

NSKeyedArchiver       归档器    拆毛线针

NSCoder                     字节片段  毛线段

反归档(织毛衣)

NSData                        字节     毛线团

NSKeyedUnarchiver   反归档器   织毛线针

NSObject                    对象     毛衣

NSCoder                     字节片段   毛线段

注意:对于每一个支持Archive的对象

1) 必须遵循NSCoding协议

2) 必须覆盖

initWithCoder

encodeWithCoder

知识点:[aCoder encodeObject:self.fatherforKey:@"father"]; // 该属性是对象,程序执行到这里会进入到该对象里进行归档(该对象必须实现归档方法),所以有多个有关联的对象只归档一个就行了

代码如下:

- (void)viewDidLoad

{

[superviewDidLoad];

MXPerson *person = [[MXPersonalloc] init];

person.name = @"张三";

person.age = 19;

// 对象 -> NSData    归档

// 1 创建可变data   构建毛线团

NSMutableData *data = [NSMutableDatadata];

// 2 创建archive对象  准备拆线器

NSKeyedArchiver *archiver = [[NSKeyedArchiveralloc] initForWritingWithMutableData:data];

// 3 编码     拆线

[archiver encodeObject:person forKey:@"person"];

// 4 完成     收线

[archiver finishEncoding];

// NSData  ->  对象

// 获取到data 构建毛线团

// 创建反归档对象   准备织毛线针

NSKeyedUnarchiver *unarchiver = [[NSKeyedUnarchiveralloc] initForReadingWithData:data];

// 织毛衣

MXPerson *p2 = [unarchiver decodeObjectForKey:@"person"];

}

三、存储总结

1. 解决的核心问题

在一台设备上保持数据

内存里的对象 <-> 硬盘上的文件

能够让内存中的对象延长生命周期

2. 渠道

1) 基础文件存储

内存对象      NSData            文件

NSString <-------------------> 文件

从右向左API:  <--

+ stringWithContentsOfFile:encoding:error:

+ stringWithContentsOfFile:usedEncoding:error:

从左向右API:->

– writeToFile:atomically:encoding:error:

NSString <---> NSData

<-

– initWithData:encoding:

->

– dataUsingEncoding:

UIImage <--------------------> 文件

<-

+ imageNamed:                 Bundle内的

+ imageWithContentsOfFile:     任何

UIImage  <----> NSData

<-

- initWithData:

NSData <------> 文件

<-

+ dataWithContentsOfFile:

->

- writeToFile:

a) 你是否需要分块读取/写入文件?

需要:请使用NSFileHandle进行文件读取,替代 NSData <----> 文件

情形:文件追加

b) 你是否需要存储自定义对象

b.1) 模型层对象少,对象简单,关系不复杂

自行构建

对象 <----> NSString

->

拼凑字符串

<-

拆分字符串

b.2) 对象结构复杂

跳转到 2)

2) Plist文件存储

plist支持对象 <-> plist文件

<-

+ arrayWithContentsOfFile:

+ dictionaryWithContentsOfFile:

->

- writeToFile:atomically:

手工处理

自定义对象 <-> plist支持对象

<->

对象         字典

+ 属性     + key-value

a) 该对象需要跨平台么?

需要:

放弃plist存储,改为自定义XML格式存储

自行构建 对象 <-> xml 的渠道

xml字符串 <-> NSData 。。。继续参考1)

b) 该数据是否是应用程序相关?

是应用程序,而不是业务相关

需要:

放弃plist存储,改为NSUserDefaults存储

c) 对象之间的关系是不是很复杂,对象的属性需要不需要可读

如果关系复杂,不需要可读

请转接 3)

3) Archive 存储

对象 <-> NSData

<-

反归档 decode unarchive

+ initWithCoder

->

归档 encode archive

- encodeWithCoder

NSData <-> 文件之间的渠道 请参见1)

1.2.3.z)

你希望不希望少写解析代码?

你希望不希望更高级的查询消息?

你希望不希望不关心文件的存储位置?

你希望不希望处理更复杂的对象关系?

如果你都希望

请转接 4)

4) SQL数据库 & Core Data

作业、

1. TMusic 升级

1) 欢迎界面只显示一次

2) 登陆过的人,不需要再登陆

不支持多帐号

单词

Archive        归档         A. Er1 Kai4 Vu.

Encode        编码         Yin3 Kou4 De.

Decode       解码         Di1 Kou4 De.

Coder      码         Kou1 De.

04-IOSCore - User Defaults、Archive、存储总结的更多相关文章

  1. MySQL Archive存储引擎

    200 ? "200px" : this.width)!important;} --> 介绍 从archive单词的解释我们大概可以明白这个存储引擎的用途,这个存储引擎基本上 ...

  2. mysql archive存储引擎导入数据报duplicate key

    DROP TABLE IF EXISTS `test`;CREATE TABLE `test` ( `id` int(10) unsigned NOT NULL AUTO_INCREMENT, `ve ...

  3. ubuntu14.04禁用USB外存储设备

    ubuntu 14.04中禁用usb外存储设备: 在网上找了很多方法,大概都是下面的命令,而实际测试的时候没有什么作用. gsettings set org.gnome.desktop.media-h ...

  4. [转帖]mysql常用存储引擎(InnoDB、MyISAM、MEMORY、MERGE、ARCHIVE)介绍与如何选择

    mysql常用存储引擎(InnoDB.MyISAM.MEMORY.MERGE.ARCHIVE)介绍与如何选择原创web洋仔 发布于2018-06-28 15:58:34 阅读数 1063 收藏展开 h ...

  5. 涂抹mysql笔记-InnoDB/MyISAM及其它各种存储引擎

    存储引擎:一种设计的存取和处理方式.为不同访问特点的表对象指定不同的存储引擎,可以获取更高的性能和处理数据的灵活性.通常是.so文件,可以用mysql命令加载它. 查看当前mysql数据库支持的存储引 ...

  6. mysql中常见的存储引擎和索引类型

    存储引擎 1.      定义 存储引擎说白了就是如何存储数据.如何为存储的数据建立索引和如何更新.查询数据等技术的实现方法.因为在关系数据库中数据的存储是以表的形式存储的,所以存储引擎也可以称为表类 ...

  7. [MySQL Reference Manual]15. 其他存储引擎

    15. 其他存储引擎 15. 其他存储引擎 15.1 设置存储引擎 15.2 MyISAM存储引擎 15.2.1 MyISAM启动选项 15.2.2 Key的空间要求 15.2.3 MyISAM表存储 ...

  8. MySQL学习笔记七:存储引擎

    1.MySQL存储引擎的设计采用“插件式”方案,用户可以很方便地选择使用哪种存储引擎,想使用mysql没有提供的引擎时,可以自己安装进去. 查看支持的存储引擎 mysql> show engin ...

  9. MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述

    MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述: 1.MySQL有多种存储引擎: MyISAM.InnoDB.MERGE.MEMORY(HEAP).BDB(Berk ...

随机推荐

  1. linux之grep用法

    运用场景:在当前目录下查找,比如代码目录,不需要在.svn目录下,以及ctags生成的tags文件中查找: grep的--exclude-dir=参数就是为了排除某个目录的,即不包含等号后面的目录: ...

  2. Java面向对象的编程

    类的多态性: Java语言中含有方法重载与成员覆盖两种形式的多态:(区别于c++) 方法重载:在一个类中,允许多个方法使用同一个名字,但方法的参数不同,完成的功能也不同. 成员覆盖:子类与父类允许具有 ...

  3. Ext.MessageBox.Show使用Progress

    在此之前,先添加引用:以下引用方式仅供参考:由于我的extjs文件夹放在script文件夹下 <link href="~/Scripts/extjs/resources/ext-the ...

  4. (译)Node.js的模块-exports和module.exports

    原文标题:Node.js Module – exports vs module.exports 原文链接:http://www.hacksparrow.com/node-js-exports-vs-m ...

  5. Light OJ 1104 Birthday Pardo(生日悖论)

    ime Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu   Description Sometime ...

  6. 我在网站开发中经常用到的几个js函数01

    这是我在最近的一个网站项目中频繁用到的几个js函数,非常实用.包括:1.js获取地址栏参数:2.返回cookies字符串中指定键对应的值:3.json格式的日期转换为正常格式4.清除cookie. / ...

  7. Tortoisegit 记住用户名和密码

    Tortoisegit 记住用户名和密码方法: [Windows系统] 当你配置好git后,在 C:\Documents and Settings\Administrator\ 目录下有一个  .gi ...

  8. [LeetCode]题解(python):012-Integer to Roman

    题目来源: https://leetcode.com/problems/integer-to-roman/ 题意分析: 这道题是要把在区间[1-3999]的数字转化成罗马数字. 题目思路: 只要知道了 ...

  9. 转: c++继承中的内存布局

    英文原文: http://www.openrce.org/articles/files/jangrayhood.pdf 翻译: http://blog.csdn.net/jiangyi711/arti ...

  10. asp.net插入sql server 中文乱码问题解决方案

    创建数据库的代码---创建promary表 create table promary ( proID int primary key, proName varchar(50) not null ) 出 ...