从可序列化对象中提取java超类,具有向后兼容性

时间:2018-03-22 15:42:36

标签: java serializable

我想将类功能移到父类,但这会降低反序列化。起点是这样的:

package xso.test.serializable;

import java.io.FileOutputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;

public class WriteClass
{
  public static void main( String[] args ) throws Exception
  {
    MyClass d = new MyClass();
    d.i = 888;

    try (ObjectOutputStream oos = new ObjectOutputStream( new FileOutputStream( "MyClass.ser" ) ))
    {
      System.out.println( "Serializing" );
      oos.writeObject( d );
    }
  }
}

class MyClass implements Serializable
{
  /**
   * same serialVersionID as in ReadClassNew
   */
  private static final long serialVersionUID = -4436695035358861227L;

  int i = 10;
}

我想将MyClass提取到一个新的SuperClass(MyNewParentClass),如下所示:

package xso.test.serializable;

import java.io.FileInputStream;
import java.io.ObjectInputStream;
import java.io.Serializable;

public class ReadClassNew
{
  public static void main( String[] args ) throws Exception
  {
    ObjectInputStream ois = new ObjectInputStream( new FileInputStream( "MyClass.ser" ) );
    System.out.println( "Deserializing" );
    MyClass clazz = (MyClass)ois.readObject();
    System.out.println( clazz.i );
  }
}

class MyNewParentClass implements Serializable
{
  /**
   * 
   */
  private static final long serialVersionUID = -6437613570659781444L;

  int i = 10;
}

class MyClass extends MyNewParentClass
{
  /**
   * same serialVersionID as in WriteClass
   */
  private static final long serialVersionUID = -4436695035358861227L;

  //int i = 10; // moved to parent class. (Field will not serialized any more sadly )
}

查看并重现问题:

  1. 运行第一个代码段。
  2. 运行第二个代码段。   控制台输出将是:

      Deserializing
      0
    
  3. 如果取消注释子类(MyClass)中的int i = 10;,您可以看到反序列化可以正常工作。但我想对超类中的字段int i进行反序列化。

    这可能吗? 谢谢你的任何建议。

1 个答案:

答案 0 :(得分:0)

我想在EJP的评论中添加一些内容。

当一个对象被序列化时,它的整个对象图被序列化。这意味着序列化对象的实例变量引用的任何对象都是序列化的,以及这些对象引用的任何对象......等等。在你的情况下,来自第一段代码的class MyClass没有关于class MyNewParentClass和它的变量的线索,所以基本上这两个指向堆上不同的内存字节。