It is a technique to save the state of an object, so that it can be used at a later time or distributed(eg : RMI)
By default, objects are not serializable. The class has to implement the serializable interface or externalizable interface for its objects to become serializable. There are other ways to serialize an object
but the one mentioned above are the most commonly used
- Since serialization operation is for objects and not classes, static member fields are not serialized.
- Sometimes we dont want to serialize certain non-static fields. This can be achieved by making them transient. Eg: password
- Implementing externalizable interface gives you more control on how an object can be serialized.
One should be careful while serializing/de-serializing a singleton object as it could lead to multiple
instances of the singleton object. If a serialized object is de-serialized multiple times, you end up with multiple copes of the object. One way to prevent is as follows
public class Singleton implements Serializable {
// This method returns the singleton instance.
protected Object readResolve() {
return getInstance();
}
}
Also if you are using a static field to store the reference to the singleton instance, then you have to override the writeObject() method to serialize it as by default static fields are not serialized.