javaserializationdeserializationexternalizable

How does Externalizable differ from Serializable?


I read that

Externalizable provides us writeExternal() and readExternal() method which gives us flexibility to control java serialization mechanism instead of relying on Java's default serialization.

But If i implement Serializable and override readObject(), writeObject(), then does not it also means the same that I am customizing serialization process?

How does it differ?

THanks.


Solution

  • Difference between Externalizable and Serializable

    1. In case of Serializable, default serialization process is used. while in case of Externalizable custom Serialization process is used which is implemented by application.
    2. JVM gives call back to readExternel() and writeExternal() of java.io.Externalizalbe interface for restoring and writing objects into persistence.
    3. Externalizable interface provides complete control of serialization process to application.
    4. readExternal() and writeExternal() supersede any specific implementation of writeObject and readObject methods.

    Though Externalizable provides complete control, it also presents challenges to serialize super type state and take care of default values in case of transient variable and static variables in Java. If used correctly Externalizable interface can improve performance of serialization process.

    So go for Externalizable interface

    When you have special requirements for the serialization of an object. For example, you may have some security-sensitive parts of the object, like passwords, which you do not want to keep and transfer somewhere. Or, it may be worthless to save a particular object referenced from the main object because its value will become worthless after restoring.