Java序列化的作用

序列化是什么:
) z9 _  m* j9 L% B, Y  序列化就是将一个对象的状态(各个属性量)保存起来,然后在适当的时候再获得。 + {/ _/ N3 }7 c& M
  序列化分为两大部分:序列化和反序列化。序列化是这个过程的第一部分,将数据分解成字节流,以便存储在文件中或在网络上传输。反序列化就是打开字节流并重构对象。对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。恢复数据要求有恢复数据的对象实例 8 P5 N, B: J% r/ ]
  序列化的什么特点: ; ~8 D& M" k9 T: N6 e. D6 K; p! t
  如果某个类能够被序列化,其子类也可以被序列化。声明为static和transient类型的成员数据不能被序列化。因为static代表类的状态, transient代表对象的临时数据。
3 `4 L9 o* g2 s% Y  什么时候使用序列化:
6 a8 W- c+ |' t3 m1 F! i  一:对象序列化可以实现分布式对象。主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。 2 B7 y4 a( Q' ?& R' h
  二:java对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的"深复制",即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列。 9 \( k! \( n' {' T$ i3 Z" B
  ====================== - o( w, }  Z/ M+ W
  可以看看接口java.io.serializable的中文解释:
2 I4 \, u6 e+ `+ g' h5 ]. y5 ~  Serializable
! O- {6 O" u5 \  public interface Serializable
) h- e' Y6 v( ^. ?6 Q  类通过实现 java.io.Serializable 接口以启用其序列化功能。未实现此接口的类将无法使其任何状态序列化或反序列化。可序列化类的所有子类型本身都是可序列化的。序列化接口没有方法或字段,仅用于标识可序列化的语义。
; e; g5 S' o$ ]* b) v$ R, |  要允许不可序列化类的子类型序列化,可以假定该子类型负责保存和还原超类型的公用 (public)、受保护的 (protected) 和(如果可访问)包 (package) 字段的状态。仅在子类型扩展的类有一个可访问的无参数构造方法来初始化该类的状态时,才可以假定子类型有此责任。如果不是这种情况,则声明一个类为可序列化类是错误的。该错误将在运行时检测到。
; q2 U( e: D1 D/ G8 B- F% H3 G  在反序列化过程中,将使用该类的公用或受保护的无参数构造方法初始化不可序列化类的字段。可序列化的子类必须能够访问无参数的构造方法。可序列化子类的字段将从该流中还原。 ( v" d6 V' B7 l6 C0 t8 D
 

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