Skip to main content

Object serialization in java


Serialization is the conversion of an object to a series of bytes, so that the object can be easily saved to persistent storage or streamed across a communication link. The byte stream can then be deserialized - converted into a replica of the original object.




When you want to serialize an object, that respective class should implement the marker interface serializable. It just informs the compiler that this java class can be serialized. You can tag properties that should not be serialized as transient. You open a stream and write the object into it.

Code for serialization of a java class :



Data.java

package com.codetalk.serialization;

import java.io.Serializable;

public class Data implements Serializable {
 
 private static final long serialVersionUID = 1L;
 
 private String firstName;
 private String lastName;
 
 /**
  * @return the firstName
  */
 public String getFirstName() {
  return firstName;
 }
 /**
  * @param firstName the firstName to set
  */
 public void setFirstName(String firstName) {
  this.firstName = firstName;
 }
 /**
  * @return the lastName
  */
 public String getLastName() {
  return lastName;
 }
 /**
  * @param lastName the lastName to set
  */
 public void setLastName(String lastName) {
  this.lastName = lastName;
 }

}


Serialization.java

package com.codetalk.serialization;

import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;

public class Serialization {

 public static void main(String[] args) {
  
  Data   data = new Data();
  String file = "/home/rakesh/data.txt";
  
  data.setFirstName("Rakesh KR");
  data.setLastName("KR");

  try {
   FileOutputStream   fileOut = new FileOutputStream(file);
   ObjectOutputStream out     = new ObjectOutputStream(fileOut);
   out.writeObject(data);
   out.close();
   fileOut.close();
   System.out.println("Serialized data is saved in : "+file);
  } catch(IOException i) {
   i.printStackTrace();
  } catch(Exception e){
   e.printStackTrace();
  } finally{
   data = null;
  }
 }
}


DeSerialization.java
package com.codetalk.serialization;

import java.io.FileInputStream;
import java.io.IOException;
import java.io.ObjectInputStream;

public class Deserialization {
 
 public static void main(String[] args) {

  Data   data = null;
  String file = "/home/rakesh/data.txt";
  
  try {
   FileInputStream fileIn = new FileInputStream(file);
   ObjectInputStream in   = new ObjectInputStream(fileIn);
   data = (Data) in.readObject();
   in.close();
   fileIn.close();
  } catch (IOException i) {
   i.printStackTrace();
   return;
  } catch (ClassNotFoundException c) {
   System.out.println("Data class not found");
   c.printStackTrace();
  }
  
  System.out.println("Deserializing Object...");
  System.out.println("First Name  : "+data.getFirstName());
  System.out.println("Last  Name  : "+data.getLastName());
  
 }
 
}


Output :
Deserializing Object...
First Name  : Rakesh KR
Last  Name  : KR

Comments

Popular posts from this blog

System.out.println In Java

System  is a class in the  java .lang package.  out  is a static member of the  System  class, and is an instance of  java .io.PrintStream .  println  is a method of  java .io.PrintStream . This method is overloaded to print message to output destination, which is typically a console or file. System is a class, that has a public static field out . So it's more like. public final class System { /** * The "standard" output stream. This stream is already * open and ready to accept output data. Typically this stream * corresponds to display output or another output destination * specified by the host environment or user. * <p> * For simple stand-alone Java applications, a typical way to write * a line of output data is: * <blockquote><pre> * System.out.println(data) * </pre></blockquote> * <p> * See the <code>println...

JSON (JavaScript Object Notation)

JSON (JavaScript Object Notation) is an open standard file format and data interchange format that uses human-readable text to store and transmit data objects consisting of attribute–value pairs and arrays (or other serializable values). It is a common data format with diverse uses in electronic data interchange, including that of web applications with servers. JSON is a language-independent data format. It was derived from JavaScript, but many modern programming languages include code to generate and parse JSON-format data. JSON filenames use the extension .json. Any valid JSON file is a valid JavaScript (.js) file, even though it makes no changes to a web page on its own. Douglas Crockford originally specified the JSON format in the early 2000s. He and Chip Morningstar sent the first JSON message in April 2001. Official website :- https://json.org/

Amazon DynamoDB : Fully managed proprietary NoSQL database service

 Amazon DynamoDB is a fully managed proprietary NoSQL database service that supports key–value and document data structures and is offered by Amazon.com as part of the Amazon Web Services portfolio. Dynamo had a multi-leader design requiring the client to resolve version conflicts and DynamoDB uses synchronous replication across multiple data centers for high durability and availability.  DynamoDB was announced by Amazon CTO Werner Vogels on January 18, 2012, and is presented as an evolution of Amazon SimpleDB. DynamoDB differs from other Amazon services by allowing developers to purchase a service based on throughput, rather than storage. If Auto Scaling is enabled, then the database will scale automatically. To prevent data loss, DynamoDB features a two-tier backup system of replication and long-term storage. Each partition features three nodes, each of which contains a copy of that partition's data. Each node also contains two data structures: a B tree used to locate items,...