Java 序列化

  class Student implements Serializable {
  ....
  }


   //Student对象序列化过程  
   FileOutputStream fos = new FileOutputStream(file); 
   ObjectOutputStream oos = new ObjectOutputStream(fos); 
   oos.writeObject(st); 
   oos.flush(); 
   oos.close(); 
   fos.close(); 

   //Student对象反序列化过程  
   FileInputStream fis = new FileInputStream(file); 
   ObjectInputStream ois = new ObjectInputStream(fis); 
   Student st1 = (Student) ois.readObject(); 
   System.out.println("name = " + st1.getName()); 
   System.out.println("sex = " + st1.getSex()); 
   System.out.println("year = " + st1.getYear()); 
   System.out.println("gpa = " + st1.getGpa()); 
   ois.close(); 
   fis.close(); 

1.Java序列化与反序列化

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

2.为什么需要序列化与反序列化

我们知道,当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。那么当两个Java进程进行通信时,能否实现进程间的对象传送呢?答案是可以的。如何做到呢?这就需要Java序列化与反序列化了。换句话说,一方面,发送方需要把这个Java对象转换为字节序列,然后在网络上传送;另一方面,接收方需要从字节序列中恢复出Java对象。

当我们明晰了为什么需要Java序列化和反序列化后,我们很自然地会想Java序列化的好处。其好处一是实现了数据的持久化,通过序列化可以把数据永久地保存到硬盘上(通常存放在文件里),二是,利用序列化实现远程通信,即在网络上传送对象的字节序列。

Java的serialization提供了一种持久化对象实例的机制。当持久化对象时,可能有一个特殊的对象数据成员,我们不想用serialization机制来保存它。为了在一个特定对象的一个域上关闭serialization,可以在这个域前加上关键字transient。

你可能感兴趣的:(Java 序列化)