我正在使用 JavaSerializable
接口和ObjectOutputStream
序列化对象(到目前为止,这种方法已经足够我的目的了)。
我的 API 依赖于对象身份进行某些操作,我想知道它是否会被序列化保留。也就是说:如果对于任意两个对象a
和b
,a == b
在序列化前成立,反序列化后还成立吗?
我发现了一些与之相反的文本——但他们要么写的是 JRE 的旧版本(我只对 1.6 和也许 1.5 感兴趣),要么关注 RMI(这与我无关)。
关于对象身份的文档不是很及时。sun.com 上的一篇技术文章提到ObjectOutputStream
对对象使用缓存,这对我来说只有在确实保留了对象身份时才有意义,但我没有足够的信心依赖这个脆弱的证据。
我已经尝试过了(Java 1.6,OS X),发现是的,对象的身份通过序列化保持不变。但是我可以从这些结果中推断出来还是它们不可靠?
对于我的测试,我序列化了以下对象图:
C----------+
| b1 b2 |
+----------+
| |
v v
B---+ B---+
| a | | a |
+---+ +---+
\ /
\ /
\/
A----+
| |
+----+
最小的复制代码:
import java.io.*;
public class SerializeTest {
static class A implements Serializable {}
static class B implements Serializable {
final A a;
public B(A a) {
this.a = a;
}
}
static class C implements Serializable {
final B b1, b2;
public C() {
A object = new A();
b1 = b2 = new B(object);
}
}
public static void main(String[] args) throws IOException,
ClassNotFoundException {
C before = new C();
System.out.print("Before: ");
System.out.println(before.b1.a == before.b2.a);
// Serialization.
ByteArrayOutputStream data = new ByteArrayOutputStream();
ObjectOutputStream out = new ObjectOutputStream(data);
out.writeObject(before);
out.close();
// Deserialization.
ObjectInputStream in =
new ObjectInputStream(new ByteArrayInputStream(data.toByteArray()));
C after = (C) in.readObject();
System.out.print("After: ");
System.out.println(after.b1.a == after.b2.a);
}
}