1 / 18

Serialization What is Serialization

Serialization What is Serialization. Serialization is the process of converting an object, or a connected graph of objects, stored within computer memory, into a linear sequence of bytes Use the sequence of bytes in several ways: Send it to another process

efrem
Télécharger la présentation

Serialization What is Serialization

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. SerializationWhat is Serialization • Serialization is the process of converting an object, or a connected graph of objects, stored within computer memory, into a linear sequence of bytes • Use the sequence of bytes in several ways: • Send it to another process • Send it to the clipboard, to be browsed or used by another application • Send it to another machine • Send it to a file on disk

  2. SerializationObject Graph • What is an object graph? • An object graph is a set of objects with some set of references to each other • The most obvious problem is how to represent the links between the objects in the Serialized stream 3 Dog Cat Cat 1 Mouse 4 7 2 Duck 9 Horse

  3. SerializationHow Serialization Works • Because run-time metadata 'knows' about each object's layout in memory, and its field and property definitions, you can serialize objects automatically, without having to write code to serialize each field • The serialized stream might be encoded using XML, or a compact binary representation • The format is decided by the the Formatter object that you call: • Binary • SOAP • Custom

  4. using System; namespaceVideoLibrary {     [Serializable] publicenumGenre { Drama, Comedy, Western, ScienceFiction, Horror, Family };     [Serializable] publicclassVideoInfo     { publicstring Title { get; set; } publicGenre Category { get; set; } publicstring Director { get; set; } publicint Year { get; set; } publicTimeSpan Duration { get; set; } publicstring Review { get; set; }     } } Serializaiton Example - VideoLibrary Worksheet 4 from http://www.cse.ohio-state.edu/~crawfis/cse459_CSharp/index.html

  5. namespaceVideoLibrary { publicpartialclassMyVideoLibraryForm : Form     { List<VideoInfo> videoLib = newList<VideoInfo>(); … privatevoidsaveLibraryToolStripMenuItem_Click(object sender, EventArgs e)         { if (this.saveLibraryDialog.ShowDialog() == DialogResult.OK)             { XmlSerializer s = newXmlSerializer(videoLib.GetType()); using (TextWriter w = newStreamWriter(saveLibraryDialog.FileName))                 { s.Serialize(w, videoLib);                 }             }         } Serializaiton Example - VideoLibrary File->Save menu Worksheet 4 from http://www.cse.ohio-state.edu/~crawfis/cse459_CSharp/index.html

  6. privatevoidopenToolStripMenuItem_Click(object sender, EventArgs e)         { if (this.openLibraryDialog.ShowDialog() == DialogResult.OK)             { XmlSerializer s = newXmlSerializer(videoLib.GetType()); using (TextReader reader = newStreamReader(openLibraryDialog.FileName))                 { List<VideoInfo> newVideos = (List<VideoInfo>)s.Deserialize(reader); foreach( VideoInfo video innewVideos) bindingVideoLib.Add(video);                 }             }         } Serializaiton Example - VideoLibrary File->Import menu Worksheet 4 from http://www.cse.ohio-state.edu/~crawfis/cse459_CSharp/index.html

  7. Serialization Scenarios • Persistence • Remoting-By-Value • Remoting-By-Reference • Transacted Persistence

  8. SerializationBasic Serialization • A Type is NOT Serializable unless Type is specifically marked as Serializable • The Serializable Attribute • The Non-Serializable Attribute [Serializable] public class MyClass {} [Serializable] public class MyClass { [NotSerialized] int _cashSize; }

  9. Serialization • It is easy to write the individual fields of a record object to a file • For example, we can create a record that stores information about a student • Name • Address • ID number • Course enrolled for • etc • We can output each field of this record to a file (either text or binary)

  10. Serialization Record file string stringint string StudentInfo Name Address ID number Course Info

  11. Serialization • In this example, any program that needs to read the file needs to know the format of the data • 2 strings, an int and then a string • Also whether each item is on a separate line • .NET serializationallows complete objects to be read or written with a single statement (.NET does the plumbing for you using reflection). • A serialized object is an object represented as a sequence of bytes. • Information is stored about the data types of the objects instance fields as well as their values • Allows the object to be reconstructed (de-serialized) from the sequence of bytes.

  12. Serialization Record file StudentInfo object StudentInfo Name Address ID number Course Info

  13. Serialization • To serialize an object, the object class needs to be marked with the [Serializable] attribute or needs to implement the ISerializable interface • Requires the System.Runtime.Serialization namespace • Also we require a formatter to serialize/de-serialize the object before writing to or reading from file • IFormatter - BinaryFormatter • XMLSerializer (why is this not an IFormatter?)

  14. SerializationISerializable Interface • Customize the serialization process • If a class implements ISerializable, that interface will always be called in preference to default serialization. • The ISerializable interface only contains one method: voidGetObjectData (SerializationInfo info, StreamingContext context); And an implied constructor that may be private. private <T> (SerializationInfo info, StreamingContext)

  15. SerializationAdditional Attributes • The serialization framework allows you to also specify methods to be called when an instance is being deserialized, after it is deserialized, before it is serialized, etc. • [OnDeserialized] – see the MSDN example.

  16. SerializationIDeserializationEventListener • If an object implements IDeserializationEventListener, the serialization infrastructure will call that class‘ OnDeserialization method as soon as the entire graph has been deserialized and all fix-ups completed • Provide a reasonable opportunity for objects that need to do fix-ups based on the state of their children

  17. Serialization • Binary serialization is limited as only .NET applications can deserialize the data stream • For more general inter-operability especially across a network, xml serialization is used • xml is text based and self descibing and universal • Comprised name/attribute pairs • xml serialization easy to implement and uses text streams

  18. Serialization • We need to insert xml tags into our StudentInfo class • Only public properties and fields can be serialized [XmlRoot("studentInfo")] public class StudentInfo { [XmlAttribute("name")] public string Name; [XmlAttribute("address")] public string Address; [XmlAttribute("course")] public string CourseInfo; [XmlAttribute("id")] private int ID; public StudentInfo() { } public StudentInfo(String n, String a, String ci, int id) { Name = n; Address = a; CourseInfo = ci; ID = id; } }

More Related