Skip to main content

Flexibility of Serializability in Java

What is Serialization in Java?


The mechanism where an object state is represented as a byte stream. Here, all object data as well as the information regarding the object such as its type are also included.

Deserialization, which is the reverse mechanism can be used to recreate the same object.


Why is Java Serialization important?


It is JVM independent, meaning that the object can be serialized at one platform and deserialized at another. Therefore it is used ti transfer object state across networks.


How to serialize an object?

  • Implement java.io.Serializable interface
  • All fields must be serializable. (If a Java Standard class implements java.io.Serializable interface, then it is serializable).
  • Whichever fields you do not wish to serialize should be marked as transient.

 import java.io.Serializable;  
 class User implements Serializable {  
      public int uid;  
      public String name;  
      public String address;  
 }  


Now, the class is eligible for Serialization.

The java.io.Serializable interface doesn't declare any methods. It is a marker interface which says that this class can be serialized.

Serialization

public static void main(String args[]){  
      try(ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("temp.out"))){  
        User user = new User();  
        oos.writeObject(user);  
        oos.flush();  
      } catch (FileNotFoundException ex) {  
        Logger.getLogger(Test.class.getName()).log(Level.SEVERE, null, ex);  
      } catch (IOException ex) {  
        Logger.getLogger(Test.class.getName()).log(Level.SEVERE, null, ex);  
     }  
}  


ObjectOutputStream class is used to serialize an object. Its writeObject method contains the algorithm that requires an object to be serialized.


Deserialization

public static void main(String args[]){  
      try(ObjectInputStream oin = new ObjectInputStream(new FileInputStream("temp.out"))){  
        User user = (User) oin.readObject();  
        System.out.println("User's name: " + user.name);  
      } catch (FileNotFoundException ex) {  
        Logger.getLogger(Test.class.getName()).log(Level.SEVERE, null, ex);  
      } catch (IOException ex) {  
        Logger.getLogger(Test.class.getName()).log(Level.SEVERE, null, ex);  
     }  
}  

ObjectInputStream class is used to serialize an object. Its readObject method contains the algorithm that requires an object to be deserialized.


Serialization algorithm in brief

  • Write the metadata of the class associated with an instance.
  • Recursively write the description of the superclass until it finds java.lang.object.
  • Once it finishes, start with the actual data associated with the instance starting from the topmost superclass.
  • Recursively write the data associated with the instance, starting from the least superclass to the most-derived class.

Comments

Popular posts from this blog

Fixing 'java RMI - ConnectException: Operation timed out' in WSO2 Enterprise Integrator 6.4

If you ever come across the below exception when running WSO2 Enterprise Integrator 6.4, here is the fix. This error occurs when you have multiple IP addresses from different networks configured in your etc/hosts as below. 10.xxx.x.xxx localhost 192.xxx.x.xxx localhost So simply, removing the unnecessary one and leaving the one of the network that you are currently connected to should resolve this issue. 10.xxx.x.xxx localhost

Student Information System - Java (SLIIT - ST2 PROJECT)

Student Information System (Github Project) This system is developed in Java and mySQL as a group project by me and 3 other members during a period of 1 month. The system allows the administrator to,  enroll students to the system  update enroll information  add/update course and degree program details  generate reports  create exams and edit relevant information  calculate gpa of the relevant exam  assign lecturers to courses  add lecturers/update details Lecturers to,  assign course grades  view their feedback  generate reports  view student / course / degree program details Students to,  view their profile  view their grading information  give feedback to lecturers   view lecturer / course / degree program details and other features. Below are some interfaces of the project. (Splash Screen) (Login) (Admin View) (Student Re...

SIMPLE BLACKJACK GAME IN JAVA (CONSOLE)

import java.util.Scanner; class BlackJack{     public static void main(String[] args)      {         int player_random1 = 100;         int player_random2 = 100;         while(player_random1 >= 12 || player_random2 >= 12  || player_random1 < 3 || player_random2 <3)         {             player_random1 = (int)(Math.random()*100);             player_random2 = (int)(Math.random()*100);         }                  int player_total = player_random1 + player_random2;                  System.out.println("You get a "+player_random1+" and a "+player_random2);         System.out.println("Your total is "+player_total); if(player_total==21)  ...