对象的序列化与反序列化.ppt
Java对象的序列化与反序列化本章内容对象序列化与反序列化的基本概念实现序列化的基本过程Serializable和Externalizable接口ObjectOutputStream和ObjectInputStream自定义序列化的两种方式默认序列化方式与自定义序列化方式的比较序列化类不同版本的序列化兼容性对象反序列化:将二进制字节流恢复为Java对象的过程。对象序列化的主要用途:将对象的字节序列永久的保存到硬盘上,通常存放在一个文件中。在网络中传输对象的字节序列。对象序列化:将Java对象转化成二进制字节流的过程。对象序列化Serializable和Externalizable接口01020304序列化的过程:Externalizable接口继承自Serializable口,05实现Serializable接口的类采用默认的序列化方式。只有实现了Serializable和Externalizable接口的类的对象才能进行序列化操作。实现Externalizable接口的类需要自行控制序列化的行为。JDK类库中的部分类(String,封装类和Date类等)都实现了Serializable接口。06ObjectInputStream和ObjectOutputStream(2)对象输入和输出流构造方法:ObjectInputStream(InputStreamin)ObjectOutputStream(OutputStreamout)见源文件:ObjectSerTest.javaObjectInputStreamObjectInputStream按照默认方式进行反序列化时,具有以下特点:如果内存中对象所属的类还没有加载,那么会加载并初始化这个类。如果在classpath中找不到相应的类文件,抛出ClassNotFoundException。在反序列化时不会调用类的任何构造方法。保存对象的文件名一般不要用.txt文件,换成.obj或.ser文件最好序列化和反序列化的顺序要一致注意的问题:对象序列化ObjectOutputStream只能对实现了Serializable接口的类的对象进行默认的序列化操作,这种操作仅仅为对象的非transient和非static的实例变量进行序列化。01见源文件:ObjectSerTest1.java02注意:静态变量属于类,不属于对象。静态变量在类加载的时候初始化,将含有静态变量的对象的序列化和反序列化分开在不同的进程中,以得到正确结果。03见源文件:WriteStudent.javaReadStudent.java04对象序列化transient成员变量transient变量不能被序列化,那么可以修饰以下类型的变量。(1)实例变量不代表对象的固有的内部数据,仅仅代表具有一定逻辑含义的临时数据。………..privateStringfirstName;privateStringlastName;privatetransientStringfullName;(2)实例变量表示一些比较敏感的信息(密码等),出于安全方面的原因不希望被序列化。(3)实例变量需要按照用户自定义的方式序列化,如经过加密后再序列化。具有关联关系的对象之间的序列化ClassTeacherimplementsSerializable{…………privateSetStudentstu=newHashSetStudent();}当序列化Teacher对象时,系统还会序列化Teacher所关联的其他可序列化的对象(Student对象)。ABCEDGHF自定义序列化方式-Serializable接口自定义序列化方式,在可序列化类中定义下面两个方法:privatevoidwriteObject(ObjectOutputStreamout)throwsIOExceptionprivatevoidreadObject(ObjectInputStreamin)throwsIOException,ClassNotFoundException注意:上述两个方法不是接口中定义的方法自定义序列化方式-S