Serialization generally refers to creating a version of the data (rather than the objects) that can be used for storage (perhaps in a file), for transfer over a network, or perhaps just for transfer between processes / AppDomain
s /etc on a single machine.
Serialization typically means writing the data as a string (think: xml / json) or as raw binary (a byte[]
etc). Deserialization is the reverse process; taking the raw data (from a file, from an incoming network socket, etc) and reconstructing the object model.
The difference between using a db is that it has no intrinsic tabular layout, and no real tie to a database; the data can be any shape, and tends to map more closely to the object-oriented layout than to the rows/columns nature of tables.
Most platforms have a range of serialization tools. For example, it sounds like you're talking about .NET - so BinaryFormatter
(.NET-specific), XmlSerializer
, DataContractSerializer
, Json.NET and protobuf-net / dotnet-protobufs would all qualify.