学习笔记——序列化和反序列化

发布时间:2022-12-11 12:00

序列化

序列化是指把一个Java对象变成二进制内容,本质上就是一个byte[]数组。 为什么要把Java对象序列化呢?因为序列化后可以把byte[]保存到文件中,或者把byte[]通过网络传输到远程,这样,就相当于把Java对象存储到文件或者通过网络传输出去了。

反序列化

即把一个二进制内容(也就是byte[]数组)变回Java对象。有了反序列化,保存到文件中的byte[]数组又可以“变回”Java对象,或者从网络上读取byte[]并把它“变回”Java对象

作用

序列化:在传递和保存对象时.保证对象的完整性和可传递性。对象转换为有序字节流,以便在网络上传输或者保存在本地文件中。

反序列化:根据字节流中保存的对象状态及描述信息,通过反序列化重建对象。

序列化算法需要做的事:

① 将对象实例相关的类元数据输出。

② 递归地输出类的超类描述直到不再有超类。(超类:被继承的类)

③ 类元数据输出完毕后,从最顶端的超类开始输出对象实例的实际数据值。

④ 从上至下递归输出实例的数据。

Java实现序列化和反序列化的过程

   1、实现序列化的必备要求:

       只有实现了Serializable或者Externalizable接口的类的对象才能被序列化为字节序列。(不是则会抛出异常) 

   2、JDK中序列化和反序列化的API:

      ①java.io.ObjectInputStream:对象输入流。

          该类的readObject()方法从输入流中读取字节序列,然后将字节序列反序列化为一个对象并返回。

     ②java.io.ObjectOutputStream:对象输出流。

          该类的writeObject(Object obj)方法将将传入的obj对象进行序列化,把得到的字节序列写入到目标输出流中进行输出。

 3、实现序列化和反序列化的三种实现:

  ①若Student类仅仅实现了Serializable接口,则可以按照以下方式进行序列化和反序列化。

             ObjectOutputStream采用默认的序列化方式,对Student对象的非transient的实例变量进行序列化。 
             ObjcetInputStream采用默认的反序列化方式,对Student对象的非transient的实例变量进行反序列化。

  ②若Student类仅仅实现了Serializable接口,并且还定义了readObject(ObjectInputStream in)和writeObject(ObjectOutputSteam out),则采用以下方式进行序列化与反序列化。

           ObjectOutputStream调用Student对象的writeObject(ObjectOutputStream out)的方法进行序列化。 
           ObjectInputStream会调用Student对象的readObject(ObjectInputStream in)的方法进行反序列化。

  ③若Student类实现了Externalnalizable接口,且Student类必须实现readExternal(ObjectInput in)和writeExternal(ObjectOutput out)方法,则按照以下方式进行序列化与反序列化。

           ObjectOutputStream调用Student对象的writeExternal(ObjectOutput out))的方法进行序列化。 
           ObjectInputStream会调用Student对象的readExternal(ObjectInput in)的方法进行反序列化。
 

 

原文链接:https://blog.csdn.net/tree_ifconfig/article/details/82766587 

ItVuer - 免责声明 - 关于我们 - 联系我们

本网站信息来源于互联网,如有侵权请联系:561261067@qq.com

桂ICP备16001015号