Java Serialization - PowerPoint PPT Presentation

1 / 12
About This Presentation
Title:

Java Serialization

Description:

Only class instances rather than primitive types can be serialized. ... An object is serialized by writing it to an ObjectOutputStream. ... – PowerPoint PPT presentation

Number of Views:742
Avg rating:3.0/5.0
Slides: 13
Provided by: pllabCs
Category:

less

Transcript and Presenter's Notes

Title: Java Serialization


1
Java Serialization
2
Serialization basics
  • Serialization is the process of transforming an
    in-memory object to a byte stream.
  • Deserialization is the inverse process of
    reconstructing an object from a byte stream to
    the same state in which the object was previously
    serialized.
  • Serializing out and serializing in are also
    used.

3
Serialization basics
  • The requirements for serialization are
    straightforward
  • Only class instances rather than primitive types
    can be serialized.
  • For an object to be serializable, its class or
    some ancestor must implement the empty
    Serializable interface.
  • An empty interface is called a marker interface.

4
Serialization basics
  • The syntax for serialization is straightforward
  • An object is serialized by writing it to an
    ObjectOutputStream.
  • An object is deserialized by reading it from an
    ObjectInputStream.

5
Serialization code
  • FileOutputStream out
  • new FileOutputStream( save.ser )
  • ObjectOutputStream oos
  • new ObjectOutputStream( out )
  • oos.writeObject( new Date() )
  • oos.close()

6
Deserialization code
  • FileInputStream in
  • new FileInputStream( save.ser )
  • ObjectInputStream ois
  • new ObjectInputStream( in )
  • Date d (Date) ois.readObject()
  • ois.close()

7
Object graphs
  • If an object has references to other objects or
    arrays, the entire object graph is serialized
    when the object is serialized.
  • The object graph consists of the object directly
    serialized and any other objects or arrays to
    which the object has direct or indirect
    references.

8
Nonserializable superclasses
  • If a serializable class C has a nonserializable
    superclass S, instances of C still can be
    serialized if S has an accessible no-argument
    constructor.
  • Ss no-argument constructor is invoked
    automatically during deserialization to construct
    the S-part of the deserialized object.

9
Serialization and primitive types
  • Technically, primitive types cannot be serialized
    or deserialized. However, the ObjectOutputStream
    implements the DataOutput interface, which
    declares methods such as writeInt to write
    primitive types to streams.
  • ObjectInputStream implements DataInput for
    reading primitive types.

10
transient and static fields
  • A field marked as transient is not impacted by
    serialization.
  • During deserialization, transient fields are
    restored to their default values (e.g., transient
    numeric fields are restored to zero).
  • static fields are not impacted by serialization.

11
Customization
  • Serialization and deserialization can be
    customized by providing private callback methods
    named writeObject and readObject, respectively.
  • The Externalizable interface can be implemented
    by classes that need to have complete control
    over serialization and deserialization.

12
Conclusion
  • The same object should not be repeatedly
    serialized to the same stream.
  • A class should not be redefined in between the
    serialization and deserialization of its
    instances.
  • Classes that need to disable serialization can
    throw a NotSerializableException in the private
    callback writeObject.
Write a Comment
User Comments (0)
About PowerShow.com