12.7. Saving Objects to Files
Problem
You have added a new class to your project and you would like to be able to save this object to disk as a file and then read it back from disk whenever required.
Solution
Make sure that your class conforms to the NSCoding
protocol and implement all the
required methods of this method. Don’t worry; I will walk you through
this in the Discussion section of this recipe.
Discussion
There are two really handy classes in iOS SDK for this specific purpose, which in the programming world is known as marshalling. They are called:
NSKeyedArchiver
A class that can archive or save the contents of an object or object tree by keys. Each value in the class, let’s say each property, can be saved to the archive, using a key that the programmer chooses. You will be given an archive file (we will talk more about this) and you will just save your values using keys that you choose. Just like a dictionary!
NSKeyedUnarchiver
This class does the reverse of the archiver class. It simply gives you the unarchived dictionary and asks you to read the values into your object’s properties.
In order for the archiver and the unarchiver to work, you need to
make sure that the objects you are asking them to archive or unarchive
conform to the NSCoding
protocol.
Let’s start with a simple Person
class. Here is the header file of our class:
@interface
Person
:NSObject
<
NSCoding
>
@property
(
nonatomic
,
copy
)
NSString
*
firstName
;
@property
(
nonatomic
,
copy
)
NSString
*
lastName
;
@end
Now if you ...
Get iOS 6 Programming Cookbook now with the O’Reilly learning platform.
O’Reilly members experience books, live events, courses curated by job role, and more from O’Reilly and nearly 200 top publishers.