序列化机制

来源:互联网 发布:nginx 支持tcp加ssl 编辑:程序博客网 时间:2024/05/17 22:03

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">Java的对象序列化机制将那些实现了Serializable接口的对象转换成一个字节序列,序列化一个对象就是将它编码成一个字节流。只要对象实现了Serializable接口,可以获得Java提供的序列化功能。</span>

public interface Serializable{
}

可以看出,此接口并没有任何方法,仅是一个标记接口。序列化是为了支持两种主要特性。一是Java的远程方法调用(RMI),当向远程对象发送消息时,需要对象序列化来传输参数和返回值。另外,对Java Beans来说,序列化也是必需的。一个Bean一般在设计阶段对它的状态信息进行配置,而且此信息必须保存下来,以便在程序启动时恢复。


序列化主要应用在I/O操作上,要通过一对输入输出流来实现。首先要创建某些OutputStream对象,然后将其封装在一个ObjectOutputStream对象内(构造时作为参数)。这时,只需调用writeObject()即可写入对象的信息,包括类的版本ID、是否实现writeObject和readObject方法、所有父类信息等,并将其发送给OutStream,所以对象的序列化结果有大量的附加信息。


类似地,反序列化过程将一个InputStream封装进ObjectInputStream,然后调用readObject(),该方法返回一个指向向上转型后的Object的引用,通过向下转型可得到正确对象。


0 0