对象的序列化和反序列化

定义:

  • 对象序列化:,就是将对象保存到磁盘中,或者在网络中传输对象

    这种机制就是使用一个字节序列表示一个对象,该字节序列包含:对象类型,对象的数据和对象中存储的属性信息

    字节序列化写到文件之后,相当于文件中持久的保存一个对象的信息

    反之,该字节序列化还可以从文件中读取出来,重构对象,对它进行反序列化

要实现序列化和反序列化就要适用对象序列化流和对象反序列化

类的序列化由实现java.io.Serializable接口的类启用。不实现此接口的类将不会使任何状态序列化或反序列化

注意: 一个对象要想被序列化,该对象所属的类必须必须实现Serializable接口

Serializable是一个标记接口,实现该接口,不需要重写任何方法

  • 对象序列化流: ObjectOutputStream
    • 将Java对象的原始数据类型和图形写入OutputStream。 可以使用ObjectnputStream读取 (重构)对象。可以通
      过使用流的文件来实现对象的持久存储。如果流是网络套接字流,则可以在另一个主机 上或另-一个进程中重构对象
      构造方法:
    • ObjectOutputStream(OutputStreamout): 创建一个写入指定的OutputStreamObjectOutputStream
      序列化对象的方法:
    • void writeObject(Object obj):将指定的对象写入ObjectOutputStream
  • 对象反序列化流:ObjectInputStream
    • ObjectInputStream反序列化先前使用ObjectOutputStream编写的原始数据和对象
      构造方法:
    • ObjectInputStream(InputStream in):创建从指定的InputStream读取的ObjectInputStream
      反序列化对象的方法:
    • Object readObject():从ObjectlnputStream读取- 个对象

例:

/*
构造方法:
ObjectInputStream (InputStream in): 创建从指定的InputStream读取的object InputStream
反序列化对象的方法:
object readobject (): 从objectInputStream读取一 个对象
*/
public class ObjectInputStreamDemot
public static void main(String[] args) throws IOException, ClassNotFoundException {
    //0bjectInputStream (InputStream in):创建从指定的InputStream读取的objectInputStream .
    ObjectInputStream ois = new ObjectInputStream(new FileInputStream( name:”myOtherStream\\oos.txt")) ;
    //object readobject (): 从objectInputStream读取一个对象
    object obj = ois.readobject();
    Student s = (Student) obj;
    System.out.println(s.getName() + "," + s.getAge());
    ois.close();|
}

serialVersionUID&transient

  • 如果序列化后的对象属性或者参数或者构造方法发生改变,反序列化时就无法读取到对象属性,因为序列化时
  • 会生成一个UID,修改对象反序列化后也会生成一个UID,造成UID值不匹配抛出异常
  • 用对象序列化流序列化了一个对象后,假如我们修改了对象所属的类文件,读取数据会不会出问题呢?
  • 会出问题, 抛出InvalidClassException异常
  • 如果出问题了,如何解决呢?
  • 给对象所属的类加一 个serialVersionUID
    private static final long serialVersionUID = 42L;
  • 如果一个对象中的某个成员变量的值不想被序列化,又该如何实现呢?
  • 给该成员变量加transient关键字修饰,该关键字标记的成员变量不参与序列化过程
上一篇:java序列化的好处及意义


下一篇:list的深度复制