序列化和反序列化(一)——概述
是什么
将堆内存中Java对象转换为字节序列的过程称为序列化(Serialization),对象转换成字节序列便于将其存储在文件中或在网络上传输;将字节序列恢复为对象的过程称为反序列化(Deserialization)。
注意:序列化时,只对对象的状态进行序列化,而不管对象的方法;
为什么
序列化与反序列化意义:
a、通过序列化可以将Java对象信息保存到磁盘文件中,通过反序列化又可以将磁盘文件中的信息恢复为Java对象。比如Tomcat服务器正常关闭时,会将还在生存时间内的session对象保存在SESSIONS.ser(默认值)文件中;Tomcat服务器重启时,会去读取文件并逐一校验其中保存的session是否过期,如过期就销毁session。
b、通过序列化可以将Java对象信息转换为诸如Json、XML等数据格式,便于对象网络传输。
怎么做
a、创建实现Serializable或Externalizable接口的实现类,只有实现Serializable或Externalizable接口的类创建的对象才允许被序列化;
b、通过ObjectOutputStream对象的writeObject()方法实现Java对象序列化操作;通过ObjectInputStream对象的readObject() 方法实现Java对象的反序列化操作