@前面讲了sqlite存储数据,现在来说一个存储类似用户配置(常见的如判断App是否是第一次启动而实现引导页)数据的类----NSUserDefaults
NSUserDefault的使用比较简单:
NSUserDefaults *mySettingData = [NSUserDefaults standardUserDefaults];
创建NSUserDefaults对象之后即可往里面添加数据,它支持的数据类型有NSString、 NSNumber、NSDate、 NSArray、NSDictionary、BOOL、NSInteger、NSFloat等系统定义的数据类型,如果要存放自定义的对象(如自定义的类对象),则必须将其转换成NSData存储:
~~~
NSArray *arr = [[NSArray alloc] initWithObjects:@"arr1", @"arr2", nil]
[mySettingData setObject:arr forKey:@"arrItem"];
[mySettingData setObject:@"admin" forKey:@"user_name"];
[mySettingData setBOOL:@YES forKey:@"auto_login"];
[mySettingData setInteger:1 forKey:@"count"];
~~~
@往NSUserDefaults添加数据后,它们就变成了全局的变量,App中即可读写NSUserDefault中的数据:
~~~
NSUserDefaults *mySetting = [NSUserDefaults standardUserDefaults];
NSLog(@"arrItem=%@", [mySetting objectForKey:@"arrItem"]);
NSLog(@"user_name=%@", [mySetting objectForKey:@"user_name"]);
NSLog(@"count=%d", [mySetting integerForKey:@"count"]);
~~~
@如果想删除某个数据项,可以使用removeObjectForKey删除数据:
[mySetting removeObjectForKey:@"arrItem"];
@需要注意的是,NSUserDefaults是定时把缓存中的数据写入磁盘的,而不是即时写入,为了防止在写完NSUserDefaults后程序退出导致的数据丢失,可以在写入数据后使用synchronize强制立即将数据写入磁盘:
[mySetting synchronize];
运行上面的语句后,NSUserDefaults中的数据即被写入到.plist文件中,如果是在模拟器上运行程序,可以在Mac的/Library/Prefereces目录下面找到一个文件名为com.apple.PeoplePicker.plist的plist文件,用Xcode打开该文件,可以看到刚才写入的数据。
@pragma mark -引导页只执行一次
~~~
if(![[NSUserDefaults standardUserDefaults] boolForKey:@"firstStart"]){
这一行-->加入引导页[self startYinDaoYe]
[[NSUserDefaults standardUserDefaults] setBool:YES forKey:@"firstStart"];
[[NSUserDefaults standardUserDefaults] synchronize];
}
~~~
@系统定义的数据类型,NSUserDefault**配合NSKeyedArchiver和NSKeyedUnarchiver做本地持久化**
这里用数组做个举例:
~~~
static NSString *const archiverKey = @"DataArray";
- (void)_testNSKeyedArchiverAndNSKeyedUnarchiver {
NSArray *setDataArray = @[@"1",@"2",@"3"];
NSData *archiverData = [NSKeyedArchiver archivedDataWithRootObject:setDataArray];
[[NSUserDefaults standardUserDefaults] setObject:archiverData forKey:archiverKey];
// 切莫忘记,依旧调用 synchronize 立即写入沙盒中
[[NSUserDefaults standardUserDefaults] synchronize];
NSArray *getDataArray = [NSArray new];
NSData *unarchiverData = [[NSUserDefaults standardUserDefaults] objectForKey:archiverKey];
getDataArray = [NSKeyedUnarchiver unarchiveObjectWithData:unarchiverData];
NSLog(@" getDataArray = %@",getDataArray);
}
~~~
@切记,数组类型为NSArray的时候可以直接getDataArray = [NSKeyedUnarchiver unarchiveObjectWithData:unarchiverData]; 如果数组类型是NSMutableArray,则必须,getDataArray = [NSMutableArray arrayWithArray:[NSKeyedUnarchiver unarchiveObjectWithData:unarchiverData]]; 否则getDataArray为nil
**@NSUserDefaults只支持: NSString, NSNumber, NSDate, NSArray, NSDictionary.
如果把一个自定义的类存到一个NSArray里,然后再存到NSUserDefaults里也是不能成功的。
那怎么办呢?
让这个自定义类实现协议中的**
**- (id) initWithCoder: (NSCoder *)coder方法**
**- (void) encodeWithCoder: (NSCoder *)coder方法,**
**然后把该自定义的类对象编码到NSData中,再从NSUserDefaults中进行读取。**
**具体可以回看我的-->数据持久化(一)序列化与反序列化**
- 前言
- 沙盒机制与文件(一)
- 沙盒机制和文件(二)
- 沙盒机制和文件(三)
- NSBundle介绍以及读取沙盒文件路径问题
- 数据持久化(一)-----归档 读写 文件路径
- 数据持久化(二)-----Sqlite
- 数据持久化(三)使用第三方类库FMDB
- 数据持久化(四)之NSUserDefaults
- 数据持久化(五)之CoreData
- 数据持久化(六)之Using CoreData with MagicalRecord
- 数据解析(一)解析XML之系统自带NSXMLParse类
- 数据解析(二)解析XML之GDataXMLNode
- 数据解析(三)解析JSON-----系统自带NSJSONSerialization 与 第三方JSONKit
- iOS多线程编程(一)NSThread
- iOS多线程编程(二)NSOperationQueue
- iOS多线程编程(三)Grand Central Dispatch(GCD)详解
- iOS网络编程(一)NSURLConnection
- iOS网络编程(二) 自定义请求网络类----推荐用于需要请求过程片段数据
- iOS网络编程(三) 异步加载及缓存图片---->SDWebImage
- iOS网络编程(四) 异步加载及缓存图片-----自定义类
- iOS网络编程(五) 异步加载及缓存图片-----EGO
- iOS网络编程(六) NSURLSession详解
- iOS网络编程(7) 第三方开源库----->AFNetworking