Java1.5的Java serialization spec说:
对于可序列化对象,将运行第一个不可序列化超类型的
构造函数。对于可序列化的类,字段被初始化为适合其类型的默认值。然后,通过调用特定于类的readObject方法恢复每个类的字段,如果没有定义这些方法,则调用defaultReadObject方法。请注意,在反序列化期间,不会为可序列化的类执行字段初始值设定项和构造函数。
然而,这意味着如果我们在类中放入一个静态变量(例如计数器变量),它将不会像往常一样被更新:
class Foo {
static int t;
public Foo() {
t++;
}
}
public class Bar extends Foo implements Serializable {
static int t;
public Bar() {
t++;
}
}
在这种情况下,如果Bar
的一个实例被反序列化,则Foo
的计数器是正确的,而Bar
的计数器是按1关闭的。
我想知道为什么反序列化不调用构造函数?因为看起来虽然这会在速度上增加一点,但它可能会导致潜在的问题。编译器可以很容易地设计为生成一个“静态构造函数”,该构造函数只更新将要更新的静态变量,并且在装入类时不依赖于外部信息。
此外,我想知道避免这种情况的最好方法是什么?我能想到的解决方案是将反序列化与对静态变量的操作打包在一起。
感谢您提前提供的任何意见!
https://stackoverflow.com/questions/7151711
复制相似问题