Hazelcast如何序列化交叉引用对象
class A implements Serializable{
public int id;
public List<B> incomingBs;
public A(int x){ this.id=x; }
}
class B implements Serializable{
public int id;
public List<A> outgoingAs;
public B(int x){ this.id=x; }
}
A a1=new A(1);
A a2=new A(2);
B b1=new B(1);
B b2=new B(2);
a1.incomingBs.add(b1);
a1.incomingBs.add(b2);
b1.outgoingAs.add(a1);
b1.outgoingAs.add(a2);
如上述代码,a1中有b1,b1中有a1。保存在Hazelcast的map中,当作序列化时,会不会引起无限循环嵌套。如果不会,那hazelcast的map 序列化机制是什么。?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
不太清楚hazelcast怎么做的。不过显然应该延迟序列化。
假设根对象为root.
反序列化时,只用先反序列化每个对象的原始类型节点,然后根据每个对象的hash值,去找已经反序列化过的某个对象,将值填入即可