为什么这个序列化逻辑会因“无法比较的可序列化字段声明”而失败?

时间:2017-07-14 20:57:47

标签: java serialization

可重现的例子:

package test;

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


public class mySerializable implements Serializable {

    private static int f;
    private static int g;

    private static final ObjectStreamField[] serialPersistentFields = {
            new ObjectStreamField("f", Integer.class),
            new ObjectStreamField("g", Integer.class),
    };

    public static void main(String[] args) {

        save();

    }
    public static void save() {
        try {
             FileOutputStream fileOut = new FileOutputStream("config" + ".ser");
             ObjectOutputStream out = new ObjectOutputStream(fileOut);
             out.writeObject(new mySerializable());
             out.close();
             fileOut.close();
        } catch (Exception ex) {
            System.out.println("save()" + ex.getLocalizedMessage());        }
    }
    public static int getF() {
        return f;
    }
    public static void setF(int f) {
        mySerializable.f = f;
    }
    public static int getG() {
        return g;
    }
    public static void setG(int g) {
        mySerializable.g = g;
    }
}

程序打印: save():test.mySerializable;声明的无法比较的可序列化字段

1 个答案:

答案 0 :(得分:1)

你有两个问题:

  • fgstatic;静态字段未序列化。
  • 他们的类型为int,而非Integer

将它们设为非静态,并使用int.class引用它们。

Ideone demo