Property list
A property list is a representation of a hierarchy of objects that can be stored in the file system and reconstituted later. Property lists give applications a lightweight and portable way to store small amounts of data. They are hierarchies of data made from specific types of objects—they are, in effect, an object graph. Property lists are easy to create programmatically and are even easier to serialize into a representation that is persistent. Applications can later read the static representation back into memory and recreate the original hierarchy of objects. Both Cocoa Foundation and Core Foundation have APIs related to property list serialization and deserialization.
Property List Types and Objects
Property lists consist only of certain types of data: dictionaries, arrays, strings, numbers (integer and float), dates, binary data, and Boolean values. Dictionaries and arrays are special types because they are collections; they can contain one or multiple data types, including other dictionaries and arrays. This hierarchical nesting of objects creates a graph of objects. The abstract data types have corresponding Foundation classes, Core Foundation types, and XML elements for collection objects and value objects, as shown in the following list:
Abstract type | Foundation framework class | Core Foundation type | XML element |
---|---|---|---|
Array | | ||
Dictionary | | ||
String | | ||
Data | | ||
Date | | ||
Integer | | | |
Floating-point value | | | |
Boolean | | | |
Mutable versions of the Foundation classes are also supported. |
Collectively, instances of these classes are known as NSMutableDictionary
NSNumber
NSString
Best Practices for Property Lists
You can write property lists out in both XML and binary formats. The binary format is much more compact than the XML version and thus more efficient. It is recommended for most situations. However, you can manually edit an XML property list if you ever need to. Property list files have the filename extension ofplist
.
You should not use property lists to store large, complex graphs of objects, especially when the objects have variable mutability settings. And you cannot use property lists to store objects that are not supported by the architecture, such as model objects. For these cases, use archiving instead. Although property lists can include NSData
Property List Serialization
To serialize and deserialize property lists, call the appropriate class methods of theNSPropertyListSerializat
CFPropertyListRef
NSData
writeToFile:atomically:
) to write that data to the file system and use the appropriate NSData
© 2012 Apple Inc. All Rights Reserved. (Last updated: 2012-02-16)