序列化和反序列化(一)——概述

是什么

        将堆内存中Java对象转换为字节序列的过程称为序列化(Serialization),对象转换成字节序列便于将其存储在文件中或在网络上传输;将字节序列恢复为对象的过程称为反序列化(Deserialization)。

       注意:序列化时,只对对象的状态进行序列化,而不管对象的方法;

为什么

序列化与反序列化意义:

        a、通过序列化可以将Java对象信息保存到磁盘文件中,通过反序列化又可以将磁盘文件中的信息恢复为Java对象。比如Tomcat服务器正常关闭时,会将还在生存时间内的session对象保存在SESSIONS.ser(默认值)文件中;Tomcat服务器重启时,会去读取文件并逐一校验其中保存的session是否过期,如过期就销毁session

       b、通过序列化可以将Java对象信息转换为诸如JsonXML等数据格式,便于对象网络传输。

怎么做

       a、创建实现SerializableExternalizable接口的实现类,只有实现SerializableExternalizable接口的类创建的对象才允许被序列化;

b、通过ObjectOutputStream对象的writeObject()方法实现Java对象序列化操作;通过ObjectInputStream对象的readObject() 方法实现Java对象的反序列化操作

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