在IOS的开发中,小数据量的持久化都用NSUserDefaults来实现,但是NSUserDefaults只能保存NSString, NSNumber, NSDate, NSArray, NSDictionary这些数据类型,但大多时候,我们会将一个对象实体做持久化的保存,由于不是大批量的数据,不会用到sqlite,那么这个时候NSUserDefaults会是很好的选择,其实对象类型可以通过NSCoding的委托方法来实现的。

  1. View Code //
  2. //  UserEntity.m
  3. //  NSCodingDemo
  4. //
  5. //  Created by   on 11-5-20.
  6. //  Copyright 2011  , Inc. All rights reserved.
  7. //
  8. #import "UserEntity.h"
  9. #import "AddressEntity.h"
  10. #define SAMPLEDATA_KEY_USERNAME (@"userName")
  11. #define SAMPLEDATA_KEY_GENDER (@"gender")
  12. #define SAMPLEDATA_KEY_AGE (@"age")
  13. #define k_FRIENDS (@"frinds")
  14. #define k_ADDRESS (@"address")
  15. #define k_userEntity_addresses (@"addresses")
  16. @implementation UserEntity
  17. @synthesize userName = _userName;
  18. @synthesize gender   = _gender;
  19. @synthesize age      = _age;
  20. @synthesize friends  = _friends;
  21. @synthesize address  = _address;
  22. @synthesize addresses = _addresses;
  23. -(void)dealloc
  24. {
  25. [self.userName release];
  26. [self.friends release];
  27. [self.address release];
  28. [self.addresses release];
  29. [super dealloc];
  30. }
  31. - (void)encodeWithCoder:(NSCoder*)coder
  32. {
  33. [coder encodeObject:self.userName forKey:SAMPLEDATA_KEY_USERNAME];
  34. [coder encodeInt:self.age forKey:SAMPLEDATA_KEY_AGE];
  35. [coder encodeBool:self.gender forKey:SAMPLEDATA_KEY_GENDER];
  36. [coder encodeObject:self.friends forKey:k_FRIENDS];
  37. [coder encodeObject:self.address forKey:k_ADDRESS];
  38. [coder encodeObject:self.addresses forKey:k_userEntity_addresses];
  39. }
  40. - (id)initWithCoder:(NSCoder*)decoder
  41. {
  42. if (self = [super init])
  43. {
  44. if (decoder == nil)
  45. {
  46. return self;
  47. }
  48. self.userName = [decoder decodeObjectForKey:SAMPLEDATA_KEY_USERNAME];
  49. self.gender = [decoder decodeBoolForKey:SAMPLEDATA_KEY_GENDER];
  50. self.age = [decoder decodeIntForKey:SAMPLEDATA_KEY_AGE];
  51. self.friends = [decoder decodeObjectForKey:k_FRIENDS];
  52. self.address = [decoder decodeObjectForKey:k_ADDRESS];
  53. self.addresses = [decoder decodeObjectForKey: k_userEntity_addresses];
  54. }
  55. return self;
  56. }
  57. @end
  1. View Code //
  2. //  AddressEntity.m
  3. //  NSCodingDemo
  4. //
  5. //  Created by   on 11-5-20.
  6. //  Copyright 2011  , Inc. All rights reserved.
  7. //
  8. #import "AddressEntity.h"
  9. #define k_Id (@"id")
  10. #define k_AddresEntity_address (@"addrss")
  11. @implementation AddressEntity
  12. @synthesize Id, address;
  13. -(void)dealloc
  14. {
  15. [self.address release];
  16. [super dealloc];
  17. }
  18. - (NSString *)description
  19. {
  20. return [NSString stringWithFormat:@"id :%d address: %@" , self.Id, self.address];
  21. }
  22. - (void)encodeWithCoder:(NSCoder*)coder
  23. {
  24. [coder encodeObject:self.address forKey:k_AddresEntity_address];
  25. [coder encodeInt:self.Id forKey:k_Id];
  26. }
  27. - (id)initWithCoder:(NSCoder*)decoder
  28. {
  29. if (self = [super init])
  30. {
  31. if (decoder == nil)
  32. {
  33. return self;
  34. }
  35. self.address = [decoder decodeObjectForKey:k_AddresEntity_address];
  36. self.Id = [decoder decodeIntForKey:k_Id];
  37. }
  38. return self;
  39. }
  40. @end
    1. View Code -(IBAction)write:(id)sender
    2. {
    3. //get document path
    4. NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    5. NSString *documentsDirectory = [paths objectAtIndex:0];
    6. NSString *filePath = [documentsDirectory stringByAppendingPathComponent:k_FILE_NAME];
    7. NSMutableData *data = [[[NSMutableData alloc] init] autorelease];
    8. NSKeyedArchiver *archiver = [[[NSKeyedArchiver alloc] initForWritingWithMutableData:data] autorelease];
    9. UserEntity *userEntity = [[[UserEntity alloc] init] autorelease];
    10. userEntity.age = 18;
    11. userEntity.gender = NO;
    12. userEntity.userName = @"add";
    13. NSArray *friends = [[NSArray alloc] initWithObjects:@"ac", @"2", @"3", @"4", nil];
    14. userEntity.friends = friends;
    15. AddressEntity *address = [[[AddressEntity alloc] init] autorelease];
    16. address.Id = 1;
    17. address.address = @"china";
    18. userEntity.address = address;
    19. AddressEntity *address2 = [[[AddressEntity alloc] init] autorelease];
    20. address2.Id = 2;
    21. address2.address = @"china2";
    22. AddressEntity *address3 = [[[AddressEntity alloc] init] autorelease];
    23. address3.Id = 3;
    24. address3.address = @"china3";
    25. NSArray *addresses = [[NSArray alloc] initWithObjects:address2, address3 , nil];
    26. userEntity.addresses = addresses;
    27. [archiver encodeObject:userEntity forKey:@"KEY"];
    28. [archiver finishEncoding];
    29. BOOL success = [data writeToFile:filePath atomically:YES];
    30. }
    31. -(IBAction)read:(id)sender
    32. {
    33. NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    34. NSString *documentsDirectory = [paths objectAtIndex:0];
    35. NSString *filePath = [documentsDirectory stringByAppendingPathComponent:k_FILE_NAME];
    36. NSData *data = [[NSData alloc] initWithContentsOfFile:filePath];
    37. NSKeyedUnarchiver *unArchiver = [[NSKeyedUnarchiver alloc] initForReadingWithData:data];
    38. UserEntity *userEntity = [unArchiver decodeObjectForKey:@"KEY"];
    39. NSLog(@"name is %@ , friend %@ address :%@ , addresses is :%@", userEntity.userName , userEntity.friends , userEntity.address, userEntity.addresses);
    40. }

NSCoding的更多相关文章

  1. iOS 数据序列化,NSCoding, NSCoder

    iOS可以利用NSKeyedArchiver类将对象序列化成NSData存储在磁盘上,但前提是该对象所属的类必须遵从NSCoding协议. NSCoding协议包含两个方法,要序列化的类必须实现它们 ...

  2. Objective-C NSData与实现NSCoding协议进行序列化和反序列化

    1.NSData NSData是Objective-C语言中数据的基本类型,其成分可以理解为字节指针和长度的封装的类,来看看源代码 @interface NSData : NSObject <N ...

  3. [转载]iOS 归档操作 NSCoding

    最近一个项目需要保存到本地文件,想用plist,但是发现很多内容是自定义的,于是只能自己归档接档.不难,找了一篇范文大家保存一下,方便以后学习使用. 转自:http://mobile.51cto.co ...

  4. NSCoding归档

    大家都知道ios中数据持久化的方式有plist sqlite coredata nscoding 而nscoding不需要关心模型属性有多少个,是什么类型,不需要定义归档文件的规则. 下面给个类大家用 ...

  5. IOS开发-- NScoding 序列化

    开篇 1到底这个序列化有啥作用? 面向对象的程序在运行的时候会创建一个复杂的对象图,经常要以二进制的方法序列化这个对象图,这个过程叫做Archiving. 二进制流可以通过网络或写入文件中(来源于某教 ...

  6. ios 沙盒 NSCoding(相当于JAVA对象序列化) 归档 数据存储

    通过NSCoding能实现像JAVA一样能够实现对象的序列化,可以保存对象到文件里. NSCoding 跟其他存储方式略有不同,他可以存储对象 对象存储的条件是: 对象需要遵守 NSCoding 协议 ...

  7. iOS开发——OC篇&协议篇/NSCoder/NSCoding/NSCoping

    协议篇/NSCoder/NSCoding/NSCoping 协议声明类需要实现的的方法,为不同的类提供公用方法,一个类可以有多个协议,但只能有一个父类,即单继承.它类似java中的接口. 正式协议(f ...

  8. Runtime之NSCoding的自动归档、接档

    为什么要有Runtime的NSCoding的自动归档.接档 大家所熟知的方法 //归档方法 - (void)encodeWithCoder:(NSCoder *)aCoder { //当学生被归档,学 ...

  9. (四十一)数据持久化的NSCoding实现 -实现普通对象的存取

    NSCoding可以用与存取一般的类对象,需要类成为NSCoding的代理,并且实现编码和解码方法. 假设类Person有name和age两个属性,应该这样设置类: .h文件: #import < ...

  10. Runtime应用(三)实现NSCoding的自动归档和自动解档

    当我们需要将一个对象进行归档时,都要让该对象的类遵守NSCoding协议,再实现归档和接档方法.例如有一个Person类,该类有两个成员变量 @property (nonatomic,copy) NS ...

随机推荐

  1. Codeforces Round #321 (Div. 2) E

    终于补好了. 题目链接: http://codeforces.com/contest/580/problem/E E. Kefa and Watch time limit per test 1 sec ...

  2. Ubuntu 16.04安装CrossOver容器来安装QQ(终极解决办法,亲测有效)

    说明:此版本的QQ基本完美,但是有个缺点就是历史记录有些会显示乱码! 注意:此方法能完美解决这篇文章http://www.cnblogs.com/EasonJim/p/7118693.html的所有问 ...

  3. 【spring boot Mybatis】报错:org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.newhope.interview.dao.UserMapper.add

    报错如下: org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): com.newhope.i ...

  4. 系统重装 WIN7如何创建和使用VHD文件

    1 在磁盘管理中,点击操作-创建VHD,然后可以创建一个空的VHD文件   2 右击这个磁盘,点击初始化磁盘,然后可以新建简单卷   3 右击这个磁盘,设置为脱机或者联机就可以在计算机中显示和隐藏这个 ...

  5. 【C#】高级语言特有的单例模式

    public class Singleton { private Singleton () { } // 变量标记为 readonly.第一次引用类的成员或创建实例时,仅仅实例化一次instance对 ...

  6. PJzhang:python基础入门的7个疗程-two

    猫宁!!! 参考链接:易灵微课-21天轻松掌握零基础python入门必修课-售价29元人民币 https://www.liaoxuefeng.com/wiki/1016959663602400 htt ...

  7. C++中结构和类的区别

    首先从从语言角度来看,c语言是一种结构化的语言,便于按照模块化的方式来组织程序,易于程序员的调试和维护,而对于c++来说,我么可以认为它是标准c的超集.实际上所有的c程序也是c++程序.但两者之间还是 ...

  8. 整理对Spark SQL的理解

    Catalyst Catalyst是与Spark解耦的一个独立库,是一个impl-free的运行计划的生成和优化框架. 眼下与Spark Core还是耦合的.对此user邮件组里有人对此提出疑问,见m ...

  9. Comparable 和 Comparator的理解

    对Comparable 的解释 Comparable是一个排序接口 此接口给实现类提供了一个排序的方法,此接口有且只有一个方法 public int compareTo(T o); compareTo ...

  10. u-boot简单学习笔记(一)

    一:Bootloader启动结构:      由于 Boot Loader 的实现依赖于 CPU 的体系结构,因此大多数 Boot Loader 都分为 stage1 和 stage2 两大部分.依赖 ...