Java序列化与反序列化

来源:互联网 发布:淘宝一颗钻在哪看 编辑:程序博客网 时间:2024/06/07 22:34

1.Java序列化和反序列化

 Java序列化是指把Java对象转换为字节序列的过程;而Java反序列化是指把字节序列恢复为Java对象的过程。

2.为什么进行java序列化与反序列化

 当两个进程进行远程通信时,可以相互发送各种类型的数据这些数据都会以二进制序列的形式在网络上传送。当两个Java进程进行通信时,可以通过Java序列化与反序列化实现进程间的对象传送。发送方需要把这个Java对象转换为字节序列,然后在网络上传送;接收方需要从字节序列中恢复出Java对象。

采用Java序列化与反序列化技术的好处,一是可以实现数据的持久化;二是可以对象数据的远程通信。

3.java序列化和反序列化的实现方式可以通过实现Serializable接口来实现。

一类被序列化成功,两个条件必须满足:

这个类必须实现java.io.Serializable接口。

所有在类中的字段必须是可序列化的。如果一个字段不是可序列化的,必须注明短暂的。

1)序列化对象

ObjectOutputStream类用于序列化一个对象。下面SerializeDemo程序实例化一个Employee对象,并将其序列化到一个文件中。

当程序执行完毕,一个名为employee.ser被创建。程序不会产生任何输出,但研究代码,并尝试确定哪些程序正在做什么。

注:当序列化一个对象到一个文件中,在Java标准惯例给定的文件扩展名为 .ser 。

import java.io.*;public class SerializeDemo{   public static void main(String [] args)   {      Employee e = new Employee();      e.name = "Ali";      e.address = "Peer";      e.number = 10;      try      {         FileOutputStream fileOut = new FileOutputStream("/tmp/employee.ser");         ObjectOutputStream out = new ObjectOutputStream(fileOut);         out.writeObject(e);         out.close();         fileOut.close();         System.out.printf("Serialized data is saved in /tmp/employee.ser");      }catch(IOException e)      {          e.printStackTrace();      }   }}

2)反序列化对象:

下面DeserializeDemo程序反序列化的SerializeDemo程序创建的Employee对象。研究程序,并尝试确定其输出:

import java.io.*;public class DeserializeDemo{   public static void main(String [] args)   {      Employee e = null;      try      {         FileInputStream fileIn = new FileInputStream("/tmp/employee.ser");         ObjectInputStream in = new ObjectInputStream(fileIn);         e = (Employee) in.readObject();         in.close();         fileIn.close();      }catch(IOException i)      {         i.printStackTrace();         return;      }catch(ClassNotFoundException c)      {         System.out.println("Employee class not found");         c.printStackTrace();         return;      }      System.out.println("Deserialized Employee...");      System.out.println("Name: " + e.name);      System.out.println("Address: " + e.address);      System.out.println("Number: " + e.number);    }}